雷火电竞-中国电竞赛事及体育赛事平台

歡迎來到入門教程網(wǎng)!

C#教程

當(dāng)前位置:主頁(yè) > 軟件編程 > C#教程 >

C#中各種計(jì)時(shí)器用法小結(jié)

來源:本站原創(chuàng)|時(shí)間:2020-01-10|欄目:C#教程|點(diǎn)擊:

本文實(shí)例總結(jié)了C#中各種計(jì)時(shí)器用法。分享給大家供大家參考,具體如下:

1、使用 Stopwatch 類 (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 可以開始測(cè)量運(yùn)行時(shí)間;使用 Stop 可以停止測(cè)量運(yùn)行時(shí)間。通過屬性 Elapsed、ElapsedMilliseconds 或 ElapsedTicks 查詢運(yùn)行時(shí)間值。當(dāng)實(shí)例正在運(yùn)行或已停止時(shí),可以查詢運(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í)開始累計(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 類將使用該計(jì)數(shù)器來測(cè)量運(yùn)行時(shí)間;否則,Stopwatch 類將使用系統(tǒng)計(jì)數(shù)器來測(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(); //若沒有 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不依賴窗體,是從線程池喚醒線程,是傳統(tǒng)的計(jì)時(shí)器為了在服務(wù)器環(huán)境上運(yùn)行而優(yōu)化后的更新版本。

4、線程計(jì)時(shí)器(System.Threading.Timer)

線程計(jì)時(shí)器也不依賴窗體,是一種簡(jiǎn)單的、輕量級(jí)計(jì)時(shí)器,它使用回調(diào)方法而不是使用事件,并由線程池線程提供支持。

5、System.Environment.TickCount

TickCount屬性用來獲取來自計(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類(System.TimeSpan)

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

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)容感興趣的讀者可查看本站專題:《C#日期與時(shí)間操作技巧總結(jié)》、《C#字符串操作技巧總結(jié)》、《C#數(shù)組操作技巧總結(jié)》、《C#中XML文件操作技巧匯總》、《C#常見控件用法教程》、《WinForm控件用法總結(jié)》、《C#數(shù)據(jù)結(jié)構(gòu)與算法教程》及《C#面向?qū)ο蟪绦蛟O(shè)計(jì)入門教程》

希望本文所述對(duì)大家C#程序設(shè)計(jì)有所幫助。

上一篇:WCF實(shí)現(xiàn)的計(jì)算器功能實(shí)例

欄    目:C#教程

下一篇:C# wx獲取token的基本方法

本文標(biāo)題:C#中各種計(jì)時(shí)器用法小結(jié)

本文地址:http://www.jygsgssxh.com/a1/C_jiaocheng/5673.html

網(wǎng)頁(yè)制作CMS教程網(wǎng)絡(luò)編程軟件編程腳本語(yǔ)言數(shù)據(jù)庫(kù)服務(wù)器

如果侵犯了您的權(quán)利,請(qǐng)與我們聯(lián)系,我們將在24小時(shí)內(nèi)進(jìn)行處理、任何非本站因素導(dǎo)致的法律后果,本站均不負(fù)任何責(zé)任。

聯(lián)系QQ:835971066 | 郵箱:835971066#qq.com(#換成@)

Copyright © 2002-2020 腳本教程網(wǎng) 版權(quán)所有