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


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

查看所有标签

猜你喜欢:

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

小米生态链战地笔记

小米生态链战地笔记

小米生态链谷仓学院 / 中信出版集团 / 2017-5 / 56.00

2013年下半年,小米开始做一件事,就是打造一个生态链布局IoT(物联网);2016年年底,小米生态链上已经拥有了77家企业,生态链企业整体销售额突破100亿元。这3年,是小米生态链快速奔跑的3年,也是小米在商场中不断厮杀着成长的3年。 3年,77家生态链企业,16家年销售额破亿,4家独角兽公司,边实战,边积累经验。 小米生态链是一个基于企业生态的智能硬件孵化器。过去的3年中,在毫无先......一起来看看 《小米生态链战地笔记》 这本书的介绍吧!

CSS 压缩/解压工具
CSS 压缩/解压工具

在线压缩/解压 CSS 代码

RGB转16进制工具
RGB转16进制工具

RGB HEX 互转工具

URL 编码/解码
URL 编码/解码

URL 编码/解码