c# – 奇怪的表现行为

栏目: ASP.NET · 发布时间: 5年前

内容简介:翻译自:https://stackoverflow.com/questions/7544438/strange-performance-behavior
我正在使用Visual Studio 2010 SP1,目标框架是2.0,平台目标:任何CPU,在 Windows

7 x64 SP1下进行测试.

我遇到了奇怪的表现行为.

如果没有app.config,或者使用以下app.config,它会使我的程序运行缓慢(秒表显示~0.11秒)

<?xml version="1.0"?>
<configuration>
  <startup >
    <supportedRuntime version="v2.0.50727" />
  </startup>
</configuration>

以下app.config使我的程序运行速度提高了0.5倍(秒表显示~0.02秒)

<?xml version="1.0"?>
<configuration>
  <startup >
    <supportedRuntime version="v4.0.30319" sku=".NETFramework,Version=v4.0" />
  </startup>
</configuration>

这是测试程序代码:

using System;
using System.Collections.Generic;
using System.Text;
using System.Diagnostics;

class Program
{
    static void Main(string[] args)
    {
        Stopwatch sw = new Stopwatch();

        while (true)
        {
            sw.Reset();
            sw.Start();

            for (int i = 0; i < 1000000; i++ )
            {
                "blablabla".IndexOf("ngrhotbegmhroes", StringComparison.OrdinalIgnoreCase);
            }

            Console.WriteLine(sw.Elapsed);
        }
    }
}

我坐了几个小时,无法弄清楚这里发生了什么.

你有什么想法吗?

听起来你刚刚发现.NET 4的速度要快得多.默认情况下,您的应用程序正在运行其构建目标的框架.当你强制它使用.NET 4时,它会更快.这可能是JIT编译器的改进,它碰巧遇到了你的情况,或者它可能是一个框架改进 – 但是在新版本中某些东西更快的情况应该不会太令人惊讶.

(对于它的价值,如果我是你的话,我会增加迭代次数…在.NET 4下我的盒子上,每次迭代只有10ms,这不是一个很好的测量.我喜欢基准测试至少几秒钟.)

(和米奇一样,我可以确认我看到同样的效果.)

编辑:我刚刚进一步调查了这一点,看到了一个有趣的效果……我假设我们正在调用haystack.IndexOf(needle,StringComparison.OrdinalIgnoreCase):

>在.NET 2上,结果大致相同,无论“针”是多大

>在.NET 4上:

>如果针比干草堆大(根据您的示例),.NET 4比.NET 2快得多

>如果needle与haystack的大小相同,则.NET 4比.NET 2慢一点

>如果针小于haystack,.NET 4比.NET 2慢很多

(这是一个测试,针的第一个字符永远不会出现在大海捞针,顺便说一句.)

翻译自:https://stackoverflow.com/questions/7544438/strange-performance-behavior


以上就是本文的全部内容,希望本文的内容对大家的学习或者工作能带来一定的帮助,也希望大家多多支持 码农网

查看所有标签

猜你喜欢:

本站部分资源来源于网络,本站转载出于传递更多信息之目的,版权归原作者或者来源机构所有,如转载稿涉及版权问题,请联系我们

互联网+

互联网+

马化腾 / 中信出版社 / 2015-5-1 / CNY 58.00

中国进入新常态,李克强总理制定*“互联网+”行动计划以推动经济进一步发展,并认为站在“互联网+”风口顺势而为,可以使经济飞起来。 《互联网+:国家战略行动路线图》由“互联网+”理念的提出者于扬、*强有力推动者马化腾等创作。书稿从理论层面、实践经验等多个角度,结合当下各产业的现状、发展趋势,全方位进行阐述,以通俗易懂的文字将这一经济发展新引擎呈现出来,并对读者如何抓住新时期的机遇有切实的指导意......一起来看看 《互联网+》 这本书的介绍吧!

UNIX 时间戳转换
UNIX 时间戳转换

UNIX 时间戳转换

RGB CMYK 转换工具
RGB CMYK 转换工具

RGB CMYK 互转工具

HEX HSV 转换工具
HEX HSV 转换工具

HEX HSV 互换工具