聯系我們 - 廣告服務 - 聯系電話:
您的當前位置: > 關注 > > 正文

為什么用Thread.Sleep函數把線程掛起時間?關于Thread.sleep的兩個問題

來源:CSDN 時間:2023-03-06 08:04:45

我們可能經常會用到 Thread.Sleep 函數把線程掛起一段時間。那么你有沒有正確的理解這個函數的用法呢?

思考下面這兩個問題:

問題一:


(資料圖片僅供參考)

假設現在是 2008-4-7 12:00:00.000,如果我調用一下 Thread.Sleep(1000) ,在 2008-4-7 12:00:01.000 的時候,這個線程會不會被喚醒?

問題二:

某人的代碼中用了一句看似莫明其妙的話:Thread.Sleep(0) 。既然是 Sleep 0 毫秒,那么他跟去掉這句代碼相比,有啥區別么?

先回顧一下系統原理:

操作系統中,CPU競爭有很多種策略。Unix系統使用的是時間片算法,而Windows則屬于搶占式的。

在時間片算法中,所有的進程排成一個隊列。操作系統按照他們的順序,給每個進程分配一段時間,即該進程允許運行的時間。如果在時間片結束時進程還在運行,則CPU將被剝奪并分配給另一個進程。如果進程在時間片結束前阻塞或結束,則CPU當即進行切換。調度程 序所要做的就是維護一張就緒進程列表,當進程用完它的時間片后,它被移到隊列的末尾。

所謂搶占式操作系統,就是說如果一個進程得到了 CPU 時間,除非它自己放棄使用 CPU ,否則將完全霸占 CPU 。因此可以看出,在搶 占式操作系統中,操作系統假設所有的進程都是“人品很好”的,會主動退出 CPU 。

在搶占式操作系統中,假設有若干進程,操作系統會根據他們的優先級、饑餓時間(已經多長時間沒有使用過 CPU 了),給他們算出一 個總的優先級來。操作系統就會把 CPU 交給總優先級最高的這個進程。當進程執行完畢或者自己主動掛起后,操作系統就會重新計算一 次所有進程的總優先級,然后再挑一個優先級最高的把 CPU 控制權交給他。

回答第一個問題:

對于第一個問題,答案是:不一定。因為你只是告訴操作系統:在未來的1000毫秒內我不想再參與到CPU競爭。那么1000毫秒過去之后,這時候也許另外一個線程正在使用CPU,那么這時候操作系統是不會重新分配CPU的,直到那個線程掛起或結束;況且,即使這個時候恰巧輪到操作系統進行CPU 分配,那么當前線程也不一定就是總優先級最高的那個,CPU還是可能被其他線程搶占去。

與此相似的,Thread有個Resume函數,是用來喚醒掛起的線程的。好像上面所說的一樣,這個函數只是“告訴操作系統我從現在起開始參與CPU競爭了”,這個函數的調用并不能馬上使得這個線程獲得CPU控制權。

回答第二個問題:

對于第二個問題,答案是:有,而且區別很明顯。Thread.Sleep(0)的作用,就是“觸發操作系統立刻重新進行一次CPU競爭”。競爭的結果也許是當前線程仍然獲得CPU控制權,也許會換成別的線程獲得CPU控制權。這也是我們在大循環里面經常會寫一句Thread.Sleep(0) ,因為這樣就給了其他線程比如Paint線程獲得CPU控制權的權力,這樣界面就不會假死在那里。

責任編輯:

標簽: 操作系統

精彩放送:

新聞聚焦

關于我們 | 聯系我們 | 投稿合作 | 法律聲明 | 廣告投放

版權所有©2017-2020   太陽信息網京ICP備2021034106號-55

所載文章、數據僅供參考,使用前務請仔細閱讀網站聲明。本站不作任何非法律允許范圍內服務!

聯系我們:55 16 53 8 @qq.com

Top 岛国精品在线