Linux和Windows系統(tǒng)線程間的區(qū)別
WIN32里的進(jìn)程/線程是繼承自O(shè)S/2的。在WIN32里,進(jìn)程是指一個(gè)程序,而線程是一個(gè)進(jìn)程里的一個(gè)執(zhí)行線索。從核心上講, WIN32的多進(jìn)程與Linux并無多大的區(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不再難懂)
評(píng)論