C#中各種計(jì)時(shí)器用法小結(jié)
本文實(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ù) 2 stopwatch.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í)器是為單線程環(huán)境設(shè)計(jì)的,這個(gè)計(jì)時(shí)器是使用最簡(jiǎn)單的一種,只要把工具箱中的Timer控件拖到窗體上,然后設(shè)置一下事件和間隔時(shí)間等屬性就可以了。
3、基于服務(wù)器的計(jì)時(shí)器(System.Timers.Timer)
System.Timers.Timer不依賴(lài)窗體,是從線程池喚醒線程,是傳統(tǒng)的計(jì)時(shí)器為了在服務(wù)器環(huán)境上運(yùn)行而優(yōu)化后的更新版本。
4、線程計(jì)時(shí)器(System.Threading.Timer)
線程計(jì)時(shí)器也不依賴(lài)窗體,是一種簡(jiǎn)單的、輕量級(jí)計(jì)時(shí)器,它使用回調(diào)方法而不是使用事件,并由線程池線程提供支持。
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ì)有所幫助。
相關(guān)文章
VS2019下安裝和破解?DevExpress?19.2?插件的詳細(xì)教程
這篇文章主要介紹了VS2019?安裝并破解?DevExpress?19.2?插件的詳細(xì)教程,本文通過(guò)圖文并茂的形式給大家介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或工作具有一定的參考借鑒價(jià)值,需要的朋友可以參考下2022-03-03使用C#實(shí)現(xiàn)基于TCP和UDP協(xié)議的網(wǎng)絡(luò)通信程序的基本示例
這篇文章主要介紹了使用C#實(shí)現(xiàn)基于TCP和UDP協(xié)議的網(wǎng)絡(luò)通信程序的示例,文中分別編寫(xiě)了基本的服務(wù)器端和客戶端,代碼十分簡(jiǎn)單,需要的朋友可以參考下2016-04-04基于WPF繪制一個(gè)點(diǎn)贊大拇指動(dòng)畫(huà)
這篇文章主要為大家詳細(xì)介紹了WPF實(shí)現(xiàn)繪制一個(gè)點(diǎn)贊大拇指動(dòng)畫(huà),文中的示例代碼講解詳細(xì),對(duì)我們學(xué)習(xí)或工作有一定幫助,感興趣的小伙伴可以了解一下2023-02-02C# 顯示、隱藏窗口對(duì)應(yīng)的任務(wù)欄
WPF中全屏窗口,會(huì)自動(dòng)隱藏任務(wù)欄,那非全屏窗口如何隱藏任務(wù)欄?甚至有沒(méi)有一種場(chǎng)景,隱藏任務(wù)后自定義一套系統(tǒng)任務(wù)欄來(lái)顯示?這篇文章主要介紹了C# 顯示、隱藏窗口對(duì)應(yīng)的任務(wù)欄,需要的朋友可以參考下2021-10-10c# 獲得當(dāng)前絕對(duì)路徑的方法(超簡(jiǎn)單)
下面小編就為大家分享一篇c# 獲得當(dāng)前絕對(duì)路徑的方法(超簡(jiǎn)單),具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過(guò)來(lái)看看吧2018-01-01Unity ScrollView實(shí)現(xiàn)動(dòng)態(tài)列表生成
這篇文章主要為大家詳細(xì)介紹了Unity ScrollView實(shí)現(xiàn)動(dòng)態(tài)列表生成,文中示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2020-04-04