線程&進(jìn)程的同步
Event,可用于進(jìn)程間的線程的同步;內(nèi)核模式中的內(nèi)核對(duì)象
Mutex,可用于進(jìn)程間的線程的同步;內(nèi)核模式中的內(nèi)核對(duì)象
Critical Section,只能用于本進(jìn)程內(nèi)的線程間的同步;用戶模式中的
Semaphore,可以讓多個(gè)線程同時(shí)進(jìn)行。內(nèi)核模式中的內(nèi)核對(duì)象
==============================
事件對(duì)象(Event)。事件對(duì)象作為標(biāo)志在線程間傳遞信號(hào)。一個(gè)或多個(gè)線程可等待一個(gè)事件對(duì)象,當(dāng)指定的事件發(fā)生時(shí),事件對(duì)象通知等待線程可以開(kāi)始執(zhí)行。它有兩種類(lèi)型:自動(dòng)重置(auto-reset)事件和手動(dòng)重置(manual-reset)事件。
臨界區(qū)(Critical Section)。臨界區(qū)對(duì)象通過(guò)提供一個(gè)進(jìn)程內(nèi)所有線程必須共享的對(duì)象來(lái)控制線程。只有擁有那個(gè)對(duì)象的線程可以訪問(wèn)保護(hù)資源。在另一個(gè)線程可以訪問(wèn)該資源之前,前一個(gè)線程必須釋放臨界區(qū)對(duì)象,以便新的線程可以索取對(duì)象的訪問(wèn)權(quán)。
互斥量(Mutex Semaphore)。互斥量的工作方式非常類(lèi)似于臨界區(qū),只是互斥量不僅保護(hù)一個(gè)進(jìn)程內(nèi)為多個(gè)線程使用的共享資源,而且還可以保護(hù)系統(tǒng)中兩個(gè)或多個(gè)進(jìn)程之間的的共享資源。
信號(hào)量(Semaphore)。信號(hào)量可以允許一個(gè)或有限個(gè)線程訪問(wèn)共享資源。它是通過(guò)計(jì)數(shù)器來(lái)實(shí)現(xiàn)的,初始化時(shí)賦予計(jì)數(shù)器以可用資源數(shù),當(dāng)將信號(hào)量提供給一個(gè)線程時(shí),計(jì)數(shù)器的值減1,當(dāng)一個(gè)線程釋放它時(shí),計(jì)數(shù)器值加1。當(dāng)計(jì)數(shù)器值小于等于0時(shí),相應(yīng)線程必須等待。信號(hào)量是Windows98同步系統(tǒng)的核心。從本質(zhì)上講,互斥量是信號(hào)量的一種特殊形式。
=================================================
進(jìn)程間的通訊實(shí)現(xiàn)(IPC)的11種方法
進(jìn)程通常被定義為一個(gè)正在運(yùn)行的程序的實(shí)例,它由兩個(gè)部分組成:
一個(gè)是操作系統(tǒng)用來(lái)管理進(jìn)程的內(nèi)核對(duì)象。內(nèi)核對(duì)象也是系統(tǒng)用來(lái)存放關(guān)于進(jìn)程的統(tǒng)計(jì)信息的地方
另一個(gè)是地址空間,它包含所有的可執(zhí)行模塊或DLL模塊的代碼和數(shù)據(jù)。它還包含動(dòng)態(tài)分配的空間。如線程堆棧和堆分配空間。每個(gè)進(jìn)程被賦予它自己的虛擬地址空間,當(dāng)進(jìn)程中的一個(gè)線程正在運(yùn)行時(shí),該線程可以訪問(wèn)只屬于它的進(jìn)程的內(nèi)存。屬于其它進(jìn)程的內(nèi)存則是隱藏的,并不能被正在運(yùn)行的線程訪問(wèn)。
為了能在兩個(gè)進(jìn)程之間進(jìn)行通訊,由以下幾種方法可供參考:
0。剪貼板Clipboard: 在16位時(shí)代常使用的方式,CWnd中提供支持
1。窗口消息 標(biāo)準(zhǔn)的Windows消息以及專(zhuān)用的WM_COPYDATA消息 SENDMESSAGE()接收端必須有一個(gè)窗口
2。使用共享內(nèi)存方式(Shared Memory)
a.設(shè)定一塊共享內(nèi)存區(qū)域
HANDLE CreateFileMapping(HANDLE,LPSECURITY_ATTRIBUTES, DWORD, DWORD, DWORD, LPCSTR)
產(chǎn)生一個(gè)file-mapping核心對(duì)象
LPVOID MapViewOfFile(
HANDLE hFileMappingObject,
DWORD dwDesiredAcess,
DWORD dwFileOffsetHigh,
DWORD dwFileOffsetLow,
DWORD dwNumberOfBytesToMap
);
得到共享內(nèi)存的指針
b.找出共享內(nèi)存
決定這塊內(nèi)存要以點(diǎn)對(duì)點(diǎn)(peer to peer)的形式呈現(xiàn)
每個(gè)進(jìn)程都必須有相同的能力,產(chǎn)生共享內(nèi)存并將它初始化。每個(gè)進(jìn)程
都應(yīng)該調(diào)用CreateFileMapping(),然后調(diào)用GetLastError().如果傳回的
錯(cuò)誤代碼是ERROR_ALREADY_EXISTS,那么進(jìn)程就可以假設(shè)這一共享內(nèi)存區(qū) 域已經(jīng)被別的進(jìn)程打開(kāi)并初始化了,否則該進(jìn)程就可以合理的認(rèn)為自己 排在第 一位,并接下來(lái)將共享內(nèi)存初始化。
還是要使用client/server架構(gòu)中
只有server進(jìn)程才應(yīng)該產(chǎn)生并初始化共享內(nèi)存。所有的進(jìn)程都應(yīng)該使用
HANDLE OpenFileMapping(DWORD dwDesiredAccess,
BOOL bInheritHandle,
LPCTSTR lpName);
再調(diào)用MapViewOfFile(),取得共享內(nèi)存的指針
c.同步處理(Mutex)
d.清理(Cleaning up) BOOL UnmapViewOfFile(LPCVOID lpBaseAddress);
CloseHandle()
3。動(dòng)態(tài)數(shù)據(jù)交換(DDE)通過(guò)維護(hù)全局分配內(nèi)存使的應(yīng)用程序間傳遞成為可能
其方式是再一塊全局內(nèi)存中手工放置大量的數(shù)據(jù),然后使用窗口消息傳遞內(nèi)存 指針.這是16位WIN時(shí)代使用的方式,因?yàn)樵赪IN32下已經(jīng)沒(méi)有全局和局部?jī)?nèi)存 了,現(xiàn)在的內(nèi)存只有一種就是虛存。
4。消息管道(Message Pipe)
用于設(shè)置應(yīng)用程序間的一條永久通訊通道,通過(guò)該通道可以象自己的應(yīng)用程序
訪問(wèn)一個(gè)平面文件一樣讀寫(xiě)數(shù)據(jù)。
匿名管道(Anonymous Pipes)
單向流動(dòng),并且只能夠在同一電腦上的各個(gè)進(jìn)程之間流動(dòng)。
命名管道(Named Pipes)
雙向,跨網(wǎng)絡(luò),任何進(jìn)程都可以輕易的抓住,放進(jìn)管道的數(shù)據(jù)有固定的格 式,而使用ReadFile()只能讀取該大小的倍數(shù)。
可以被使用于I/O Completion Ports
5 郵件槽(Mailslots)
廣播式通信,在32系統(tǒng)中提供的新方法,可以在不同主機(jī)間交換數(shù)據(jù),在 WIN9X下只支持郵件槽客戶
6。Windows套接字(Windows Socket)
它具備消息管道所有的功能,但遵守一套通信標(biāo)準(zhǔn)使的不同操作系統(tǒng)之上的應(yīng) 用程序之間可以互相通信。
7。Internet通信 它讓?xiě)?yīng)用程序從Internet地址上載或下載文件
8。RPC:遠(yuǎn)程過(guò)程調(diào)用,很少使用,因其與UNIX的RPC不兼容。
9。串行/并行通信(Serial/Parallel Communication)
它允許應(yīng)用程序通過(guò)串行或并行端口與其他的應(yīng)用程序通信
10。COM/DCOM
通過(guò)COM系統(tǒng)的代理存根方式進(jìn)行進(jìn)程間數(shù)據(jù)交換,但只能夠表現(xiàn)在對(duì)接口 函數(shù)的調(diào)用時(shí)傳送數(shù)據(jù),通過(guò)DCOM可以在不同主機(jī)間傳送數(shù)據(jù)。
Mutex,可用于進(jìn)程間的線程的同步;內(nèi)核模式中的內(nèi)核對(duì)象
Critical Section,只能用于本進(jìn)程內(nèi)的線程間的同步;用戶模式中的
Semaphore,可以讓多個(gè)線程同時(shí)進(jìn)行。內(nèi)核模式中的內(nèi)核對(duì)象
==============================
事件對(duì)象(Event)。事件對(duì)象作為標(biāo)志在線程間傳遞信號(hào)。一個(gè)或多個(gè)線程可等待一個(gè)事件對(duì)象,當(dāng)指定的事件發(fā)生時(shí),事件對(duì)象通知等待線程可以開(kāi)始執(zhí)行。它有兩種類(lèi)型:自動(dòng)重置(auto-reset)事件和手動(dòng)重置(manual-reset)事件。
臨界區(qū)(Critical Section)。臨界區(qū)對(duì)象通過(guò)提供一個(gè)進(jìn)程內(nèi)所有線程必須共享的對(duì)象來(lái)控制線程。只有擁有那個(gè)對(duì)象的線程可以訪問(wèn)保護(hù)資源。在另一個(gè)線程可以訪問(wèn)該資源之前,前一個(gè)線程必須釋放臨界區(qū)對(duì)象,以便新的線程可以索取對(duì)象的訪問(wèn)權(quán)。
互斥量(Mutex Semaphore)。互斥量的工作方式非常類(lèi)似于臨界區(qū),只是互斥量不僅保護(hù)一個(gè)進(jìn)程內(nèi)為多個(gè)線程使用的共享資源,而且還可以保護(hù)系統(tǒng)中兩個(gè)或多個(gè)進(jìn)程之間的的共享資源。
信號(hào)量(Semaphore)。信號(hào)量可以允許一個(gè)或有限個(gè)線程訪問(wèn)共享資源。它是通過(guò)計(jì)數(shù)器來(lái)實(shí)現(xiàn)的,初始化時(shí)賦予計(jì)數(shù)器以可用資源數(shù),當(dāng)將信號(hào)量提供給一個(gè)線程時(shí),計(jì)數(shù)器的值減1,當(dāng)一個(gè)線程釋放它時(shí),計(jì)數(shù)器值加1。當(dāng)計(jì)數(shù)器值小于等于0時(shí),相應(yīng)線程必須等待。信號(hào)量是Windows98同步系統(tǒng)的核心。從本質(zhì)上講,互斥量是信號(hào)量的一種特殊形式。
=================================================
進(jìn)程間的通訊實(shí)現(xiàn)(IPC)的11種方法
進(jìn)程通常被定義為一個(gè)正在運(yùn)行的程序的實(shí)例,它由兩個(gè)部分組成:
一個(gè)是操作系統(tǒng)用來(lái)管理進(jìn)程的內(nèi)核對(duì)象。內(nèi)核對(duì)象也是系統(tǒng)用來(lái)存放關(guān)于進(jìn)程的統(tǒng)計(jì)信息的地方
另一個(gè)是地址空間,它包含所有的可執(zhí)行模塊或DLL模塊的代碼和數(shù)據(jù)。它還包含動(dòng)態(tài)分配的空間。如線程堆棧和堆分配空間。每個(gè)進(jìn)程被賦予它自己的虛擬地址空間,當(dāng)進(jìn)程中的一個(gè)線程正在運(yùn)行時(shí),該線程可以訪問(wèn)只屬于它的進(jìn)程的內(nèi)存。屬于其它進(jìn)程的內(nèi)存則是隱藏的,并不能被正在運(yùn)行的線程訪問(wèn)。
為了能在兩個(gè)進(jìn)程之間進(jìn)行通訊,由以下幾種方法可供參考:
0。剪貼板Clipboard: 在16位時(shí)代常使用的方式,CWnd中提供支持
1。窗口消息 標(biāo)準(zhǔn)的Windows消息以及專(zhuān)用的WM_COPYDATA消息 SENDMESSAGE()接收端必須有一個(gè)窗口
2。使用共享內(nèi)存方式(Shared Memory)
a.設(shè)定一塊共享內(nèi)存區(qū)域
HANDLE CreateFileMapping(HANDLE,LPSECURITY_ATTRIBUTES, DWORD, DWORD, DWORD, LPCSTR)
產(chǎn)生一個(gè)file-mapping核心對(duì)象
LPVOID MapViewOfFile(
HANDLE hFileMappingObject,
DWORD dwDesiredAcess,
DWORD dwFileOffsetHigh,
DWORD dwFileOffsetLow,
DWORD dwNumberOfBytesToMap
);
得到共享內(nèi)存的指針
b.找出共享內(nèi)存
決定這塊內(nèi)存要以點(diǎn)對(duì)點(diǎn)(peer to peer)的形式呈現(xiàn)
每個(gè)進(jìn)程都必須有相同的能力,產(chǎn)生共享內(nèi)存并將它初始化。每個(gè)進(jìn)程
都應(yīng)該調(diào)用CreateFileMapping(),然后調(diào)用GetLastError().如果傳回的
錯(cuò)誤代碼是ERROR_ALREADY_EXISTS,那么進(jìn)程就可以假設(shè)這一共享內(nèi)存區(qū) 域已經(jīng)被別的進(jìn)程打開(kāi)并初始化了,否則該進(jìn)程就可以合理的認(rèn)為自己 排在第 一位,并接下來(lái)將共享內(nèi)存初始化。
還是要使用client/server架構(gòu)中
只有server進(jìn)程才應(yīng)該產(chǎn)生并初始化共享內(nèi)存。所有的進(jìn)程都應(yīng)該使用
HANDLE OpenFileMapping(DWORD dwDesiredAccess,
BOOL bInheritHandle,
LPCTSTR lpName);
再調(diào)用MapViewOfFile(),取得共享內(nèi)存的指針
c.同步處理(Mutex)
d.清理(Cleaning up) BOOL UnmapViewOfFile(LPCVOID lpBaseAddress);
CloseHandle()
3。動(dòng)態(tài)數(shù)據(jù)交換(DDE)通過(guò)維護(hù)全局分配內(nèi)存使的應(yīng)用程序間傳遞成為可能
其方式是再一塊全局內(nèi)存中手工放置大量的數(shù)據(jù),然后使用窗口消息傳遞內(nèi)存 指針.這是16位WIN時(shí)代使用的方式,因?yàn)樵赪IN32下已經(jīng)沒(méi)有全局和局部?jī)?nèi)存 了,現(xiàn)在的內(nèi)存只有一種就是虛存。
4。消息管道(Message Pipe)
用于設(shè)置應(yīng)用程序間的一條永久通訊通道,通過(guò)該通道可以象自己的應(yīng)用程序
訪問(wèn)一個(gè)平面文件一樣讀寫(xiě)數(shù)據(jù)。
匿名管道(Anonymous Pipes)
單向流動(dòng),并且只能夠在同一電腦上的各個(gè)進(jìn)程之間流動(dòng)。
命名管道(Named Pipes)
雙向,跨網(wǎng)絡(luò),任何進(jìn)程都可以輕易的抓住,放進(jìn)管道的數(shù)據(jù)有固定的格 式,而使用ReadFile()只能讀取該大小的倍數(shù)。
可以被使用于I/O Completion Ports
5 郵件槽(Mailslots)
廣播式通信,在32系統(tǒng)中提供的新方法,可以在不同主機(jī)間交換數(shù)據(jù),在 WIN9X下只支持郵件槽客戶
6。Windows套接字(Windows Socket)
它具備消息管道所有的功能,但遵守一套通信標(biāo)準(zhǔn)使的不同操作系統(tǒng)之上的應(yīng) 用程序之間可以互相通信。
7。Internet通信 它讓?xiě)?yīng)用程序從Internet地址上載或下載文件
8。RPC:遠(yuǎn)程過(guò)程調(diào)用,很少使用,因其與UNIX的RPC不兼容。
9。串行/并行通信(Serial/Parallel Communication)
它允許應(yīng)用程序通過(guò)串行或并行端口與其他的應(yīng)用程序通信
10。COM/DCOM
通過(guò)COM系統(tǒng)的代理存根方式進(jìn)行進(jìn)程間數(shù)據(jù)交換,但只能夠表現(xiàn)在對(duì)接口 函數(shù)的調(diào)用時(shí)傳送數(shù)據(jù),通過(guò)DCOM可以在不同主機(jī)間傳送數(shù)據(jù)。
posted on 2008-10-19 22:42 so true 閱讀(497) 評(píng)論(0) 編輯 收藏 所屬分類(lèi): C&C++