C#中各種計時器

來源:互聯網
上載者:User
1、使用 Stopwatch 類 (System.Diagnostics.Stopwatch)

Stopwatch 執行個體可以測量一個時間間隔的已耗用時間,也可以測量多個時間間隔的總已耗用時間。在典型的 Stopwatch 方案中,先調用 Start 方法,然後調用 Stop 方法,最後使用 Elapsed 屬性檢查已耗用時間。

Stopwatch 執行個體或者在運行,或者已停止;使用 IsRunning 可以確定 Stopwatch 的目前狀態。使用 Start
可以開始測量已耗用時間;使用 Stop 可以停止測量已耗用時間。通過屬性 Elapsed、ElapsedMilliseconds 或
ElapsedTicks 查詢已耗用時間值。當執行個體正在運行或已停止時,可以查詢已耗用時間屬性。已耗用時間屬性在 Stopwatch
運行期間穩固遞增;在該執行個體停止時保持不變。

預設情況 下,Stopwatch
執行個體的已耗用時間值相當於所有測量的時間間隔的總和。每次調用 Start 時開始累計已耗用時間計數;每次調用 Stop
時結束目前時間間隔測量,並凍結累計已耗用時間值。使用 Reset 方法可以清除現有 Stopwatch 執行個體中的累計已耗用時間。

Stopwatch在基礎計時器機制中對計時器的刻度進行計數,從而測量已耗用時間。如果安裝的硬體和作業系統支援高解析度效能的計數器,則
Stopwatch 類將使用該計數器來測量已耗用時間;否則,Stopwatch 類將使用系統計數器來測量已耗用時間。使用 Frequency 和
IsHighResolution 欄位可以確定實現 Stopwatch 計時的精度和解析度。

樣本
System.Diagnostics.Stopwatch stopwatch = new System.Diagnostics.Stopwatch();

stopwatch.Start();
//任務 1...
stopwatch.Stop();
_result.Text += "<p>任務 1 用時:" + stopwatch.ElapsedTicks + "。</p>";

stopwatch.Reset(); //若沒有 Reset,則會把任務 1 的用時累計進入任務 2
stopwatch.Start();
//任務 2...
stopwatch.Stop();
_result.Text += "<p>任務 2 用時:" + stopwatch.ElapsedTicks + "。</p>";

2、基於 Windows 的標準計時器(System.Windows.Forms.Timer)

Windows 計時器是為單線程環境設計的,這個計時器是使用最簡單的一種,只要把工具箱中的Timer控制項拖到表單上,然後設定一下事件和間隔時間等屬性就可以了。

3、基於伺服器的計時器(System.Timers.Timer)

System.Timers.Timer不依賴表單,是從線程池喚醒線程,是傳統的計時器為了在伺服器環境上運行而最佳化後的更新版本。

4、線程計時器(System.Threading.Timer)

線程計時器也不依賴表單,是一種簡單的、輕量級計時器,它使用回調方法而不是使用事件,並由線程池線程提供支援。

5、System.Environment.TickCount

TickCount屬性用來擷取來自電腦的系統計時器的毫秒計數。

用法:

int startTime=System.Environment.TickCount;
......任務......
int endTime=System.Environment.TickCount;
int runTime=endTime-startTime;(注意單位是毫秒哦!)

6、使用TimeSpan類(System.TimeSpan)

    TimeSpan 對象表示時間間隔或期間,按正負天數、小時數、分鐘數、秒數以及秒的小數部分進行度量。用於度量期間的最大時間單位是天。更大的時間單位(如月和年)的天數不同,因此為保持一致性,時間間隔以天為單位來度量。

    TimeSpan 對象的值是等於所表示時間間隔的刻度數。一個刻度等於 100 納秒,TimeSpan 對象的值的範圍在 MinValue 和 MaxValue 之間。

    TimeSpan 值可以表示為 [-]d.hh:mm:ss.ff,其中減號是可選的,它指示負時間間隔,d 分量表示天,hh 表示小時(24 小時制),mm 表示分鐘,ss 表示秒,而 ff 為秒的小數部分。即,時間間隔包括整的正負天數、天數和剩餘的不足一天的時間長度,或者只包含不足一天的時間長度。例如,初始化為 1.0e+13 刻度的 TimeSpan 對象的文本表示“11.13:46:40”,即 11 天,13 小時,46 分鐘和 40 秒。

用法:

System.DateTime startTime,endTime;

System.TimeSpan time;

startTime=System.DateTime.Now;

......任務......

endTime=System.DateTime.Now;

time=endTime-startTime;

int runTime=time.Milliseconds;(以毫秒為單位)

聯繫我們

該頁面正文內容均來源於網絡整理,並不代表阿里雲官方的觀點,該頁面所提到的產品和服務也與阿里云無關,如果該頁面內容對您造成了困擾,歡迎寫郵件給我們,收到郵件我們將在5個工作日內處理。

如果您發現本社區中有涉嫌抄襲的內容,歡迎發送郵件至: info-contact@alibabacloud.com 進行舉報並提供相關證據,工作人員會在 5 個工作天內聯絡您,一經查實,本站將立刻刪除涉嫌侵權內容。

A Free Trial That Lets You Build Big!

Start building with 50+ products and up to 12 months usage for Elastic Compute Service

  • Sales Support

    1 on 1 presale consultation

  • After-Sales Support

    24/7 Technical Support 6 Free Tickets per Quarter Faster Response

  • Alibaba Cloud offers highly flexible support services tailored to meet your exact needs.