Linux 休眠(使linux休眠)
win10系統(tǒng)長時間睡眠會關(guān)機嗎?
更新一下:這個答案有點過時了,現(xiàn)在最新的Windows應(yīng)該不存在這個問題了。升級win10后,我也遇到了類似的問題:合上筆記本的蓋子待機,再打開時可能就死機了,界面卡住,需要長按電源鍵關(guān)機才行。
而且遇到藍屏的幾率也比以前大多了,錯誤代碼通常顯示是驅(qū)動造成的。
我習(xí)慣了合上蓋子就走人,可是如果死機,之前的打開的工作頁面就都沒了,還容易造成數(shù)據(jù)丟失。看了前面的許多答案,又覺得不想那么麻煩的折騰了。但我無意中找到了一個簡單的解決辦法:徹底關(guān)閉win10的休眠功能。
如果注意到win10在待機后,短時間內(nèi)喚醒只需要動幾下鼠標(biāo)或者按一下電源鍵就會立刻進入登錄界面;而長時間待機后再打開,跟你關(guān)機后再開機是一樣的,計算機會從BIOS開始啟動。
這其實是win10 的兩種待機模式,可以立刻進入登錄界面的叫做“睡眠”,此時系統(tǒng)是不會切斷內(nèi)存供電的;而超過一定時間(默認(rèn)好像是180分鐘)后,系統(tǒng)就會進入叫做”休眠“的模式,內(nèi)存中的數(shù)據(jù)被保存到硬盤中,計算機徹底斷電,此時跟關(guān)機已經(jīng)沒有什么大的區(qū)別了。
在控制面板-電源選項-編輯計劃設(shè)置-高級電源設(shè)置中把“睡眠”的選項中休眠調(diào)整為從不,“電源按鍵和蓋子”選項中也都設(shè)為睡眠,這樣使得無論你是使用電池還是電源,系統(tǒng)都不會自動進入休眠模式。
這樣,我發(fā)現(xiàn)系統(tǒng)喚醒后就可以立刻進入登錄界面,也不會發(fā)生死機的現(xiàn)象了。
休眠模式相對于睡眠模式的節(jié)能優(yōu)勢并不大,還省去了喚醒后的等待時間。
你仍然可以主動休眠,或者在其他電源計劃中設(shè)置休眠以備不時之需。
這樣設(shè)置后對我個人又有了一些額外的好處。
我在筆記本上裝了win10和Linux的雙系統(tǒng),以前休眠喚醒時還要經(jīng)過系統(tǒng)選擇的界面,又增加了很多時間。
更重要的是,win10休眠或開啟快速啟動關(guān)機時,會禁止非Windows訪問它的磁盤。
我之前關(guān)閉快速啟動或者重新啟動都不好使,現(xiàn)在我發(fā)現(xiàn)這個問題也解決了。在Windows很好的解決這些問題之前,這算是一個不錯的權(quán)宜之計吧。
sleep命令使用教程?
使用權(quán)限 : 所有使用者
使用方式 : sleep number
說明 : sleep 可以用來將目前動作延遲一段時間
參數(shù)說明 :
--help : 顯示輔助訊息
--version : 顯示版本編號
number : 時間長度,后面可接 s、m、h 或 d
其中 s 為秒,m 為 分鐘,h 為小時,d 為日數(shù)
例子 :
顯示目前時間后延遲 1 分鐘,之后再次顯示時間 :
date;sleep 1m;date
這個命令更多應(yīng)用于shell腳本編程里和程序里
如下面的一段程序:
應(yīng)用程序:
#include <syswait.h>
usleep(n) //n微秒
Sleep(n)//n毫秒
sleep(n)//n秒
驅(qū)動程序:
#include <linux/delay.h>
mdelay(n) //milliseconds 其實現(xiàn)
#ifdef notdef
#define mdelay(n) (
{unsigned long msec=(n); while (msec--) udelay(1000);})
#else
#define mdelay(n) (
(__builtin_constant_p(n) && (n)<=MAX_UDELAY_MS) ? udelay((n)*1000) :
({unsigned long msec=(n); while (msec--) udelay(1000);}))
#endif
調(diào)用asm/delay.h的udelay,udelay應(yīng)該是納秒級的延時
Dos:
sleep(1); //停留1秒
delay(100); //停留100毫秒
Windows:
Sleep(100); //停留100毫秒
Linux:
sleep(1); //停留1秒
usleep(1000); //停留1毫秒
每一個平臺不太一樣,最好自己定義一套跨平臺的宏進行控制
秒還是微秒?關(guān)于延時函數(shù)sleep()
因為要寫一段代碼,需要用到sleep()函數(shù),在我印象中,sleep(10)好像是休眠10微秒,結(jié)果卻是休眠了10秒(在Linux下)。覺得很奇怪,因為頭兒也記得好像是微秒為單位的。所以就查了一下。
原來linux下的sleep函數(shù)原型為:
unsigned int sleep(unsigned int seconds);
而MFC中的Sleep函數(shù)原型為:
void Sleep(DWORD dwMilliseconds);
也就是說,Linux下(使用的gcc的庫),sleep()函數(shù)是以秒為單位的,sleep(1);就是休眠1秒。而MFC下的sleep()函數(shù)是以微秒為單位的,sleep(1000);才是休眠1秒。原來如此啊。而如果在Linux下也用微妙為單位休眠,可以使用線程休眠函數(shù):void usleep(unsigned long usec);當(dāng)然,使用的時候別忘記#include <system.h>哦。
另外值得一提的是,linux下還有個delay()函數(shù),原型為extern void delay(unsigned int msec);它可以延時msec*4毫秒,也就是如果想延時一秒鐘的話,可以這么用 delay(250)。
linux內(nèi)核信號的實現(xiàn)原理?
從最初的原子操作,到后來的信號量,從大內(nèi)核鎖到今天的自旋鎖。這些同步機制的發(fā)展伴隨Linux從單處理器到對稱多處理器的過渡;伴隨著從非搶占內(nèi)核到搶占內(nèi)核的過度。Linux的鎖機制越來越有效,也越來越復(fù)雜。Linux的內(nèi)核鎖主要是自旋鎖和信號量。自旋鎖最多只能被一個可執(zhí)行線程持有,如果一個執(zhí)行線程試圖請求一個已被爭用(已經(jīng)被持有)的自旋鎖,那么這個線程就會一直進行忙循環(huán)——旋轉(zhuǎn)——等待鎖重新可用。要是鎖未被爭用,請求它的執(zhí)行線程便能立刻得到它并且繼續(xù)進行。自旋鎖可以在任何時刻防止多于一個的執(zhí)行線程同時進入臨界區(qū)。Linux中的信號量是一種睡眠鎖。如果有一個任務(wù)試圖獲得一個已被持有的信號量時,信號量會將其推入等待隊列,然后讓其睡眠。這時處理器獲得自由去執(zhí)行其它代碼。當(dāng)持有信號量的進程將信號量釋放后,在等待隊列中的一個任務(wù)將被喚醒,從而便可以獲得這個信號量。
手機休眠會怎么樣?
手機休眠會讓你手機得到一個臨時的修正,讓這些零部件在全身為你服務(wù)的同時達到一個修整的時間,這樣在你換妾手機睡眠之后,手機的性能得到一個充分的運用。并且在手機休眠的過程中,會讓你電池續(xù)航能力變得更強。但睡眠之中可能有一些及時的通訊數(shù)據(jù)就接收不到了。
linux設(shè)備休眠的方式?
常用的休眠方式有freeze,standby, mem, disk
freeze: 凍結(jié)I/O設(shè)備,將它們置于低功耗狀態(tài),使處理器進入空閑狀態(tài),喚醒最快,耗電比其它standby, mem, disk方式高
standby:除了凍結(jié)I/O設(shè)備外,還會暫停系統(tǒng),喚醒較快,耗電比其它 mem, disk方式高
mem: 將運行狀態(tài)數(shù)據(jù)存到內(nèi)存,并關(guān)閉外設(shè),進入等待模式,喚醒較慢,耗電比disk方式高
disk: 將運行狀態(tài)數(shù)據(jù)存到硬盤,然后關(guān)機,喚醒最慢
總結(jié)
以上是生活随笔為你收集整理的Linux 休眠(使linux休眠)的全部內(nèi)容,希望文章能夠幫你解決所遇到的問題。
- 上一篇: 什么是有理项 什么是有理项的定义
- 下一篇: java ee maven_针对新手的J