新聞中心

EEPW首頁 > 嵌入式系統(tǒng) > 設(shè)計(jì)應(yīng)用 > Linux和Windows系統(tǒng)線程間的區(qū)別

Linux和Windows系統(tǒng)線程間的區(qū)別

作者: 時(shí)間:2009-06-25 來源:網(wǎng)絡(luò) 收藏
熟悉WIN32編程的人一定知道,WIN32的進(jìn)程管理方式與上有著很大區(qū)別,在Unix里,只有進(jìn)程的概念,但在WIN32里卻還有一個(gè)線程的概念,那么和WIN32在這里究竟有著什么區(qū)別呢?   

WIN32里的進(jìn)程/線程是繼承自O(shè)S/2的。在WIN32里,進(jìn)程是指一個(gè)程序,而線程是一個(gè)進(jìn)程里的一個(gè)執(zhí)行線索。從核心上講, WIN32的多進(jìn)程與并無多大的區(qū)別,在WIN32里的線程才相當(dāng)于Linux的進(jìn)程,是一個(gè)實(shí)際正在執(zhí)行的代碼。但是,WIN32里同一個(gè)進(jìn)程里各個(gè)線程之間是共享數(shù)據(jù)段的。這才是與Linux的進(jìn)程最大的不同。

下面這段程序顯示了WIN32下一個(gè)進(jìn)程如何啟動(dòng)一個(gè)線程。

int g;

DWORD WINAPI ChildProcess( LPVOID lpParameter ){

int i;

for ( i = 1; i 1000; i ++) {

g ++;

printf( This is Child Thread: %dn, g );

}

ExitThread( 0 );

};

void main()

{

int threadID;

int i;

g = 0;

CreateThread( NULL, 0, ChildProcess, NULL, 0, threadID );

for ( i = 1; i 1000; i ++) {

g ++;

printf( This is Parent Thread: %dn, g );

}

}

在WIN32下,使用CreateThread函數(shù)創(chuàng)建線程,與Linux下創(chuàng)建進(jìn)程不同,WIN32線程不是從創(chuàng)建處開始運(yùn)行的,而是由 CreateThread指定一個(gè)函數(shù),線程就從那個(gè)函數(shù)處開始運(yùn)行。此程序同前面的UNIX程序一樣,由兩個(gè)線程各打印1000條信息。 threadID是子線程的線程號(hào),另外,全局變量g是子線程與父線程共享的,這就是與Linux最大的不同之處。大家可以看出,WIN32的進(jìn)程/線程要比Linux復(fù)雜,在Linux要實(shí)現(xiàn)類似WIN32的線程并不難,只要fork以后,讓子進(jìn)程調(diào)用ThreadProc函數(shù),并且為全局變量開設(shè)共享數(shù)據(jù)區(qū)就行了,但在WIN32下就無法實(shí)現(xiàn)類似fork的功能了。所以現(xiàn)在WIN32下的C語言編譯器所提供的庫函數(shù)雖然已經(jīng)能兼容大多數(shù)Linux/UNIX的庫函數(shù),但卻仍無法實(shí)現(xiàn)fork。

對(duì)于多任務(wù)系統(tǒng),共享數(shù)據(jù)區(qū)是必要的,但也是一個(gè)容易引起混亂的問題,在WIN32下,一個(gè)程序員很容易忘記線程之間的數(shù)據(jù)是共享的這一情況,一個(gè)線程修改過一個(gè)變量后,另一個(gè)線程卻又修改了它,結(jié)果引起程序出問題。但在Linux下,由于變量本來并不共享,而由程序員來顯式地指定要共享的數(shù)據(jù),使程序變得更清晰與安全。

至于WIN32的進(jìn)程概念,其含義則是應(yīng)用程序,也就是相當(dāng)于UNIX下的exec了。

linux操作系統(tǒng)文章專題:linux操作系統(tǒng)詳解(linux不再難懂)


關(guān)鍵詞: Windows Linux 系統(tǒng)線程

評(píng)論


相關(guān)推薦

技術(shù)專區(qū)

關(guān)閉