4

我想测试我的计算机性能,所以我运行了这段代码

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 万

4

1 回答 1

1

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

下面的测试控制台应用程序的输出(在多次尝试后)对于 .net 2 大约为 300、310 毫秒,对于 .NET 4 大约为 1050、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();
    }
}
于 2012-09-14T15:11:01.643 回答