加入收藏 | 设为首页 | 会员中心 | 我要投稿 李大同 (https://www.lidatong.com.cn/)- 科技、建站、经验、云计算、5G、大数据,站长网!
当前位置: 首页 > 百科 > 正文

c# – 为什么.net 2.0比4.0更快

发布时间:2020-12-15 21:40:14 所属栏目:百科 来源:网络整理
导读:我想测试我的电脑性能 所以我运行了这段代码 public partial class Form1 : Form{ public Form1() { InitializeComponent(); } private void button1_Click(object sender,EventArgs e) { DateTime dt = DateTime.Now; Int64 i = 0; do { i++; } while (dt.A
我想测试我的电脑性能
所以我运行了这段代码

public partial class Form1 : Form
{
    public Form1()
    {
        InitializeComponent();
    }

    private void button1_Click(object sender,EventArgs e)
    {
        DateTime dt = DateTime.Now;
        Int64 i = 0;
        do
        {
            i++;
        } while (dt.AddSeconds(10) >= DateTime.Now);

        this.textBox1.Text = i.ToString("n0");
    }


}

当我选择.NET Framework 2.0时,我获得了3300万的结果
但是当我选择4.0时,我只获得了900万

解决方法

不是真正的答案,但是评论太长了……问题中代码的问题似乎确实源于.NET 2和4之间的性能差异.具体来说,我看到DateTime.Now在.NET 4比2.0.

下面的测试控制台应用程序的输出(在多次尝试之后)对于.net 2和1050大约为300,310毫秒,对于.NET 4为1090毫秒.

发布代码以便其他人可以尝试其他平台,配置.我在Windows 7-64位,在发布模式下编译.

using System;
using System.Diagnostics;
class Program
{
    public static void Main(string[] args)
    {
        const int m = 1000000;
        DateTime d;

        Stopwatch s1 = Stopwatch.StartNew();
        for (int i = 0; i < m; i++)
        {
            d=DateTime.Now;
        }
        s1.Stop();

        Stopwatch s2 = Stopwatch.StartNew();
        for (int i = 0; i < m; i++)
        {
            DateTime.Now.AddSeconds(10);
        }
        s2.Stop();

        Console.WriteLine("{0},{1}",s1.ElapsedMilliseconds,s2.ElapsedMilliseconds);
        Console.Read();
    }
}

(编辑:李大同)

【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容!

    推荐文章
      热点阅读