C#中的一些延時(shí)函數(shù)
C#一些延時(shí)函數(shù)
sleep延時(shí)方法
System.Threading.Thread.Sleep(1000); //毫秒
實(shí)現(xiàn)的是非獨(dú)占性延時(shí)函數(shù),延時(shí)過時(shí)中界面仍可響應(yīng)消息:
public static void Delay(int milliSecond)
{
? ? int start = Environment.TickCount;
? ? while (Math.Abs(Environment.TickCount - start) < milliSecond)//毫秒
? ? {
? ? ? ? Application.DoEvents();//可執(zhí)行某無聊的操作
? ? }
}關(guān)于Math.Abs()
Environment.TickCount,內(nèi)部API是用DWORD GetTickCount()來實(shí)現(xiàn)的,該屬性的值從系統(tǒng)計(jì)時(shí)器派生,并以 32 位有符號(hào)整數(shù)的形式存儲(chǔ)。
因此,如果系統(tǒng)連續(xù)運(yùn)行,TickCount 將在約 24.9 天內(nèi)從零遞增至 Int32. MaxValue ,然后跳至 Int32. MinValue (這是一個(gè)負(fù)數(shù)),再在接下來的 24.9 天內(nèi)遞增至零。
DWORD是無符號(hào)的,而 Environment.TickCount屬性返回的值是有符號(hào)的,所以有一半的值用負(fù)數(shù)表示!
C#準(zhǔn)確延時(shí)函數(shù)
最近一段時(shí)間用C#寫了一個(gè)上位機(jī),由于需要用到延時(shí)函數(shù),所以給大家分享一個(gè)準(zhǔn)確延時(shí)函數(shù)
大家在網(wǎng)上一定找到過這個(gè)延時(shí)函數(shù)

用是能用,但是有一個(gè)致命問題,就是大于一分鐘的延時(shí)會(huì)陷入無限死循環(huán),于是修改了博主師傅修改了一下,修改的原理也很簡(jiǎn)單,大家可以自己理解領(lǐng)會(huì),以下是修改的源碼:
public bool Dalay(int ms)
{
DateTime now = DateTime.Now;
int s;
do
{
TimeSpan spand = DateTime.Now - now;
s = spand.Minutes * 60 * 1000 + spand.Seconds * 1000 + spand.Milliseconds;
Application.DoEvents();
}
while (s < ms);
return true;
}以上為個(gè)人經(jīng)驗(yàn),希望能給大家一個(gè)參考,也希望大家多多支持腳本之家。
相關(guān)文章
C#畫筆使用復(fù)合數(shù)組繪制單個(gè)矩形的方法
這篇文章主要介紹了C#畫筆使用復(fù)合數(shù)組繪制單個(gè)矩形的方法,涉及C#使用畫筆繪制圖形的相關(guān)技巧,需要的朋友可以參考下2015-06-06
Unity shader實(shí)現(xiàn)高斯模糊效果
這篇文章主要為大家詳細(xì)介紹了Unity shader實(shí)現(xiàn)高斯模糊效果,具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2019-02-02
Unity3D實(shí)現(xiàn)攝像機(jī)鏡頭移動(dòng)并限制角度
這篇文章主要為大家詳細(xì)介紹了Unity3D實(shí)現(xiàn)攝像機(jī)鏡頭移動(dòng)并限制角度,文中示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2020-05-05
C#中使用強(qiáng)制類型實(shí)現(xiàn)字符串和ASCII碼之間的轉(zhuǎn)換
這篇文章主要介紹了C#中使用強(qiáng)制類型實(shí)現(xiàn)字符串和ASCII碼之間的轉(zhuǎn)換,本文還給出了另一種方法,需要的朋友可以參考下2014-08-08
C#實(shí)現(xiàn)計(jì)算器功能(winform版)
這篇文章主要為大家詳細(xì)介紹了C#實(shí)現(xiàn)winform版的計(jì)算器功能,文中示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2022-01-01

