是否可以使用Environment.TickCount
来计算时间跨度?
int start = Environment.TickCount;
// Do stuff
int duration = Environment.TickCount - start;
Console.WriteLine("That took " + duration " ms");
因为TickCount
是带符号的,并将在25天后滚动(它需要50天才能达到所有32位,但如果你想弄明白任何数学意义,你必须删除有符号的位),它看起来太冒险了,没有用。
我使用的是DateTime.Now
。这是最好的方法吗?
DateTime start = DateTime.Now;
// Do stuff
TimeSpan duration = DateTime.Now - start;
Console.WriteLine("That took " + duration.TotalMilliseconds + " ms");
发布于 2008-10-28 13:41:34
使用秒表类。在msdn上有一个很好的例子:http://msdn.microsoft.com/en-us/library/system.diagnostics.stopwatch.aspx
Stopwatch stopWatch = Stopwatch.StartNew();
Thread.Sleep(10000);
stopWatch.Stop();
// Get the elapsed time as a TimeSpan value.
TimeSpan ts = stopWatch.Elapsed;
发布于 2008-10-28 13:41:46
发布于 2011-06-10 23:37:18
如果您正在寻找Environment.TickCount
的功能,但又没有创建新Stopwatch
对象的开销,则可以使用静态Stopwatch.GetTimestamp()
方法(以及Stopwatch.Frequency
)来计算较长的时间跨度。因为GetTimestamp()
返回一个long
,所以它在很长一段时间内都不会溢出(在我用来写这篇文章的机器上,超过100,000年)。它也比Environment.TickCount
更精确,后者的最大分辨率为10到16毫秒。
https://stackoverflow.com/questions/243351
复制相似问题