本文實(shí)例總結(jié)了C#中各種計(jì)時(shí)器用法。分享給大家供大家參考,具體如下:
1、使用 Stopwatch 類(lèi) (System.Diagnostics.Stopwatch)
Stopwatch 實(shí)例可以測(cè)量一個(gè)時(shí)間間隔的運(yùn)行時(shí)間,也可以測(cè)量多個(gè)時(shí)間間隔的總運(yùn)行時(shí)間。在典型的 Stopwatch 方案中,先調(diào)用 Start 方法,然后調(diào)用 Stop 方法,最后使用 Elapsed 屬性檢查運(yùn)行時(shí)間。
Stopwatch 實(shí)例或者在運(yùn)行,或者已停止;使用 IsRunning 可以確定 Stopwatch 的當(dāng)前狀態(tài)。使用 Start 可以開(kāi)始測(cè)量運(yùn)行時(shí)間;使用 Stop 可以停止測(cè)量運(yùn)行時(shí)間。通過(guò)屬性 Elapsed、ElapsedMilliseconds 或 ElapsedTicks 查詢(xún)運(yùn)行時(shí)間值。當(dāng)實(shí)例正在運(yùn)行或已停止時(shí),可以查詢(xún)運(yùn)行時(shí)間屬性。運(yùn)行時(shí)間屬性在 Stopwatch 運(yùn)行期間穩(wěn)固遞增;在該實(shí)例停止時(shí)保持不變。
默認(rèn)情況 下,Stopwatch 實(shí)例的運(yùn)行時(shí)間值相當(dāng)于所有測(cè)量的時(shí)間間隔的總和。每次調(diào)用 Start 時(shí)開(kāi)始累計(jì)運(yùn)行時(shí)間計(jì)數(shù);每次調(diào)用 Stop 時(shí)結(jié)束當(dāng)前時(shí)間間隔測(cè)量,并凍結(jié)累計(jì)運(yùn)行時(shí)間值。使用 Reset 方法可以清除現(xiàn)有 Stopwatch 實(shí)例中的累計(jì)運(yùn)行時(shí)間。
Stopwatch在基礎(chǔ)計(jì)時(shí)器機(jī)制中對(duì)計(jì)時(shí)器的刻度進(jìn)行計(jì)數(shù),從而測(cè)量運(yùn)行時(shí)間。如果安裝的硬件和操作系統(tǒng)支持高分辨率性能的計(jì)數(shù)器,則 Stopwatch 類(lèi)將使用該計(jì)數(shù)器來(lái)測(cè)量運(yùn)行時(shí)間;否則,Stopwatch 類(lèi)將使用系統(tǒng)計(jì)數(shù)器來(lái)測(cè)量運(yùn)行時(shí)間。使用 Frequency 和 IsHighResolution 字段可以確定實(shí)現(xiàn) Stopwatch 計(jì)時(shí)的精度和分辨率。
示例
System.Diagnostics.Stopwatch stopwatch = new System.Diagnostics.Stopwatch();stopwatch.Start();//任務(wù) 1...stopwatch.Stop();_result.Text += "<p>任務(wù) 1 用時(shí):" + stopwatch.ElapsedTicks + "。</p>";stopwatch.Reset(); //若沒(méi)有 Reset,則會(huì)把任務(wù) 1 的用時(shí)累計(jì)進(jìn)入任務(wù) 2stopwatch.Start();//任務(wù) 2...stopwatch.Stop();_result.Text += "<p>任務(wù) 2 用時(shí):" + stopwatch.ElapsedTicks + "。</p>";
2、基于 Windows 的標(biāo)準(zhǔn)計(jì)時(shí)器(System.Windows.Forms.Timer)
Windows 計(jì)時(shí)器是為單線(xiàn)程環(huán)境設(shè)計(jì)的,這個(gè)計(jì)時(shí)器是使用最簡(jiǎn)單的一種,只要把工具箱中的Timer控件拖到窗體上,然后設(shè)置一下事件和間隔時(shí)間等屬性就可以了。
3、基于服務(wù)器的計(jì)時(shí)器(System.Timers.Timer)
System.Timers.Timer不依賴(lài)窗體,是從線(xiàn)程池喚醒線(xiàn)程,是傳統(tǒng)的計(jì)時(shí)器為了在服務(wù)器環(huán)境上運(yùn)行而優(yōu)化后的更新版本。
4、線(xiàn)程計(jì)時(shí)器(System.Threading.Timer)
線(xiàn)程計(jì)時(shí)器也不依賴(lài)窗體,是一種簡(jiǎn)單的、輕量級(jí)計(jì)時(shí)器,它使用回調(diào)方法而不是使用事件,并由線(xiàn)程池線(xiàn)程提供支持。
5、System.Environment.TickCount
TickCount屬性用來(lái)獲取來(lái)自計(jì)算機(jī)的系統(tǒng)計(jì)時(shí)器的毫秒計(jì)數(shù)。
用法:
int startTime=System.Environment.TickCount;//......任務(wù)......int endTime=System.Environment.TickCount;int runTime=endTime-startTime;//(注意單位是毫秒哦!)
6、使用TimeSpan類(lèi)(System.TimeSpan)
TimeSpan 對(duì)象表示時(shí)間間隔或持續(xù)時(shí)間,按正負(fù)天數(shù)、小時(shí)數(shù)、分鐘數(shù)、秒數(shù)以及秒的小數(shù)部分進(jìn)行度量。用于度量持續(xù)時(shí)間的最大時(shí)間單位是天。更大的時(shí)間單位(如月和年)的天數(shù)不同,因此為保持一致性,時(shí)間間隔以天為單位來(lái)度量。
TimeSpan 對(duì)象的值是等于所表示時(shí)間間隔的刻度數(shù)。一個(gè)刻度等于 100 納秒,TimeSpan 對(duì)象的值的范圍在 MinValue 和 MaxValue 之間。
TimeSpan 值可以表示為 [-]d.hh:mm:ss.ff,其中減號(hào)是可選的,它指示負(fù)時(shí)間間隔,d 分量表示天,hh 表示小時(shí)(24 小時(shí)制),mm 表示分鐘,ss 表示秒,而 ff 為秒的小數(shù)部分。即,時(shí)間間隔包括整的正負(fù)天數(shù)、天數(shù)和剩余的不足一天的時(shí)長(zhǎng),或者只包含不足一天的時(shí)長(zhǎng)。例如,初始化為 1.0e+13 刻度的 TimeSpan 對(duì)象的文本表示“11.13:46:40”,即 11 天,13 小時(shí),46 分鐘和 40 秒。
用法:
System.DateTime startTime,endTime;System.TimeSpan time;startTime=System.DateTime.Now;//......任務(wù)......endTime=System.DateTime.Now;time=endTime-startTime;int runTime=time.Milliseconds;//(以毫秒為單位)
更多關(guān)于C#相關(guān)內(nèi)容感興趣的讀者可查看本站專(zhuān)題:《C#日期與時(shí)間操作技巧總結(jié)》、《C#字符串操作技巧總結(jié)》、《C#數(shù)組操作技巧總結(jié)》、《C#中XML文件操作技巧匯總》、《C#常見(jiàn)控件用法教程》、《WinForm控件用法總結(jié)》、《C#數(shù)據(jù)結(jié)構(gòu)與算法教程》及《C#面向?qū)ο蟪绦蛟O(shè)計(jì)入門(mén)教程》
希望本文所述對(duì)大家C#程序設(shè)計(jì)有所幫助。
新聞熱點(diǎn)
疑難解答
圖片精選
網(wǎng)友關(guān)注