windows和linux多进程效率,Windows程序效率 (转)
Windows程序效率 (轉(zhuǎn))[@more@]? 是一個(gè)龐大的功能豐富的,并且為我們提供了強(qiáng)大的應(yīng)用接口,使我們可以編寫功能豐富的應(yīng)用程序,但正因?yàn)閃indows的復(fù)雜性和應(yīng)用程序接口的強(qiáng)大,我們往往忽視了很多技術(shù)細(xì)節(jié),使得寫出來(lái)的程序較低,缺乏競(jìng)爭(zhēng)力。以下是我總結(jié)的一些提高程序效率的規(guī)則,希望對(duì)提高程序質(zhì)量有幫助。
減少程序在核心態(tài)和態(tài)之間的切換:namespace prefix = o ns = "urn:schemas--com::office" />
我們知道Windows系統(tǒng)中的應(yīng)用程序可以在兩種狀態(tài)下運(yùn)行-用戶態(tài)和核心態(tài),但是如果進(jìn)程在兩種狀態(tài)之間切換,則需要耗費(fèi)上千個(gè)周期,這對(duì)于高質(zhì)量的程序來(lái)說(shuō)是絕對(duì)不能容忍的。典型的例子是用戶線程互斥的臨界區(qū)和互斥體(Mutex),互斥體是核心態(tài),應(yīng)用程序使用它時(shí)會(huì)切換到核心態(tài),而臨界區(qū)則直接在用戶態(tài)下工作,所以如果可能,應(yīng)該用臨界區(qū)取代互斥體。
使用線程代替進(jìn)程以減少系統(tǒng)資源的開銷
在Windows系統(tǒng)中,進(jìn)程是資源非配的單位,線程是調(diào)度的單位,因?yàn)榫€程共享進(jìn)程的地址,所以與創(chuàng)建進(jìn)程相比,創(chuàng)建線程可以節(jié)省大量的系統(tǒng)資源開銷。所以對(duì)于并發(fā)計(jì)算的問(wèn)題,可以盡量使用線程機(jī)制來(lái)實(shí)現(xiàn)。
減少線程場(chǎng)景切換的開銷
線程為應(yīng)用程序提供了并發(fā)機(jī)制,使程序的多個(gè)代碼段可以“同時(shí)”運(yùn)行,比如使用多個(gè)線程提高費(fèi)時(shí)的IO操作,但是不是線程愈多越好呢?當(dāng)然不是,線程雖然使用進(jìn)程地址空間,但仍有自己的運(yùn)行環(huán)境(堆棧、臨時(shí)令牌等),線程場(chǎng)景的切換是要耗費(fèi)CPU資源的,同一個(gè)計(jì)算過(guò)程(不涉及IO操作),使用兩個(gè)線程來(lái)完成比使用一個(gè)線程來(lái)完成所需要的時(shí)間實(shí)際是更多。
減少的跨邊界(頁(yè))訪問(wèn)
在Windows系統(tǒng)中,內(nèi)存是以頁(yè)(4KB)為單位組織的,由于Windows是虛擬系統(tǒng),內(nèi)存中的頁(yè)在不用時(shí)常換出到外存中,需要用到的時(shí)候再裝入內(nèi)存,這樣可以使一個(gè)應(yīng)用程序使用比實(shí)際內(nèi)存大得多得地址范圍。但是內(nèi)存得換入換出與CPU得速度相比是很費(fèi)時(shí)的IO操作。下面有兩段幾乎完全一樣的程序,在VC下編譯為release版本后,前一段的執(zhí)行時(shí)間是后一段的200多倍
程序1:
char buf[8][4000];
char ch;
int i, j;
for(j=0; j<4000; j++)
{
for(i=0; i<8; j++)
{
ch = buf[i][j];
}
}
程序2:
char buf[8][4000];
char ch;
int i, j;
for(i=0; i<8; j++)
{
for(j=0; j<4000; j++)
{
ch = buf[i][j];
}
}
總結(jié)
以上是生活随笔為你收集整理的windows和linux多进程效率,Windows程序效率 (转)的全部?jī)?nèi)容,希望文章能夠幫你解決所遇到的問(wèn)題。
- 上一篇: linux man命令的1和1p,Lin
- 下一篇: linux 内核修改rss,linux