我想测试我的电脑性能
所以我运行了这段代码
所以我运行了这段代码
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(); } }
版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 [email protected] 举报,一经查实,本站将立刻删除。