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がはるかに遅い2.0 よりも .NET 4。

以下のテスト コンソール アプリケーションの出力 (複数回の試行後) は、.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 に答える