Linux和Windows系統(tǒng)線程間的區(qū)別
WIN32里的進程/線程是繼承自O(shè)S/2的。在WIN32里,進程是指一個程序,而線程是一個進程里的一個執(zhí)行線索。從核心上講, WIN32的多進程與Linux并無多大的區(qū)別,在WIN32里的線程才相當(dāng)于Linux的進程,是一個實際正在執(zhí)行的代碼。但是,WIN32里同一個進程里各個線程之間是共享數(shù)據(jù)段的。這才是與Linux的進程最大的不同。
下面這段程序顯示了WIN32下一個進程如何啟動一個線程。
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)建進程不同,WIN32線程不是從創(chuàng)建處開始運行的,而是由 CreateThread指定一個函數(shù),線程就從那個函數(shù)處開始運行。此程序同前面的UNIX程序一樣,由兩個線程各打印1000條信息。 threadID是子線程的線程號,另外,全局變量g是子線程與父線程共享的,這就是與Linux最大的不同之處。大家可以看出,WIN32的進程/線程要比Linux復(fù)雜,在Linux要實現(xiàn)類似WIN32的線程并不難,只要fork以后,讓子進程調(diào)用ThreadProc函數(shù),并且為全局變量開設(shè)共享數(shù)據(jù)區(qū)就行了,但在WIN32下就無法實現(xiàn)類似fork的功能了。所以現(xiàn)在WIN32下的C語言編譯器所提供的庫函數(shù)雖然已經(jīng)能兼容大多數(shù)Linux/UNIX的庫函數(shù),但卻仍無法實現(xiàn)fork。
對于多任務(wù)系統(tǒng),共享數(shù)據(jù)區(qū)是必要的,但也是一個容易引起混亂的問題,在WIN32下,一個程序員很容易忘記線程之間的數(shù)據(jù)是共享的這一情況,一個線程修改過一個變量后,另一個線程卻又修改了它,結(jié)果引起程序出問題。但在Linux下,由于變量本來并不共享,而由程序員來顯式地指定要共享的數(shù)據(jù),使程序變得更清晰與安全。
至于WIN32的進程概念,其含義則是應(yīng)用程序,也就是相當(dāng)于UNIX下的exec了。
linux操作系統(tǒng)文章專題:linux操作系統(tǒng)詳解(linux不再難懂)
評論