为什么我的秒表会在1秒钟后继续重置

sco*_*ott 5 c# stopwatch

所以我有以下代码块:

var sw = new Stopwatch();
sw.Start();
while (sw.Elapsed.Seconds<10)
{
    System.Threading.Thread.Sleep(50);
    Console.WriteLine(sw.Elapsed.Milliseconds.ToString() + " ms");
}
sw.Stop();
Run Code Online (Sandbox Code Playgroud)

在我的输出中

50 ms
101 ms
151 ms
202 ms
253 ms
304 ms
355 ms
405 ms
456 ms
507 ms
558 ms
608 ms
659 ms
710 ms
761 ms
812 ms
862 ms
913 ms
964 ms
15 ms
65 ms
116 ms
167 ms
218 ms
Run Code Online (Sandbox Code Playgroud)

为什么每1000毫秒重置一次?我需要等待10秒而且我无法使用,Thread.Sleep(10000);因为这个第三方库我也使用睡眠,我需要它在那段时间做的事情.

jas*_*son 13

因为Stopwatch.Elapsed.Milliseconds只输出经过时间的毫秒分量.它不是以毫秒为单位的总时间.这从文档中可以清楚地看出.Stopwatch.Elapsed是一个实例TimeSpanTimeSpan.Milliseconds声明:

获取当前TimeSpan结构表示的时间间隔的毫秒组件.

如果你想要以毫秒为单位的输出,并且你想要总的毫秒数,那么使用TimeSpan.TotalMilliseconds:

获取TimeSpan以整数和小数毫秒表示的当前结构的值.

总是,总是,总是检查文档!

  • +1始终检查文档. (2认同)

jer*_*enh 6

你需要的TotalMilliseconds属性sw.Elapsed,而不是sw.Elapsed.Milliseconds