《進程間共享數(shù)據(jù)》word版

《進程間共享數(shù)據(jù)》word版

ID:30381828

大小:94.56 KB

頁數(shù):19頁

時間:2018-12-29

《進程間共享數(shù)據(jù)》word版_第1頁
《進程間共享數(shù)據(jù)》word版_第2頁
《進程間共享數(shù)據(jù)》word版_第3頁
《進程間共享數(shù)據(jù)》word版_第4頁
《進程間共享數(shù)據(jù)》word版_第5頁
資源描述:

《《進程間共享數(shù)據(jù)》word版》由會員上傳分享,免費在線閱讀,更多相關(guān)內(nèi)容在應用文檔-天天文庫

1、進程間共享數(shù)據(jù)如何在進程間共享數(shù)據(jù)?1、引言在Windows程序中,各個進程之間常常需要交換數(shù)據(jù),進行數(shù)據(jù)通訊。WIN32API提供了許多函數(shù)使我們能夠方便高效的進行進程間的通訊,通過這些函數(shù)我們可以控制不同進程間的數(shù)據(jù)交換,就如同在WIN16中對本地進程進行讀寫操作一樣。典型的WIN16兩進程可以通過共享內(nèi)存來進行數(shù)據(jù)交換:(1)進程A將GlobalAlloc(GMEM_SHARE.)API分配一定長度的內(nèi)存;(2)進程A將GlobalAlloc函數(shù)返回的句柄傳遞給進程B(通過一個登錄消息);(3)進程

2、B對這個句柄調(diào)用GlobalLock函數(shù),并利用GlobalLock函數(shù)返回的指針訪問數(shù)據(jù)。這種方法在WIN32中可能失敗,這是因為GlobalLock函數(shù)返回指向的是進程A的內(nèi)存,由于進程使用的是虛擬地址而非實際物理地址,因此這一指針僅與A進程有關(guān),而于B進程無關(guān)。本文探討了幾種WIN32下進程之間通訊的幾種實現(xiàn)方法,讀者可以使用不同的方法以達到程序運行高效可靠的目的。2、Windows95中進程的內(nèi)存空間管理WIN32進程間通訊與Windows95的內(nèi)存管理有密切關(guān)系,理解Windows95的內(nèi)存管理

3、對我們?nèi)缦碌某绦蛟O(shè)計將會有很大的幫助,下面我們討論以下Windows95中進程的內(nèi)存空間管理。在WIN16下,所有Windows應用程序共享單一地址,任何進程都能夠?qū)@一空間中屬于共享單一的地址空間,任何進程都能夠?qū)@一空間中屬于其他進程的內(nèi)存進行讀寫操作,甚至可以存取操作系統(tǒng)本身的數(shù)據(jù),這樣就可能破壞其他程序的數(shù)據(jù)段代碼。在WIN32下,每個進程都有自己的地址空間,一個WIN32進程不能存取另一個地址的私有數(shù)據(jù),兩個進程可以用具有相同值的指針尋址,但所讀寫的只是它們各自的數(shù)據(jù),這樣就減少了進程之間的相互

4、干擾。另一方面,每個WIN32進程擁有4GB的地址空間,但并不代表它真正擁有4GB的實際物理內(nèi)存,而只是操作系統(tǒng)利用CPU的內(nèi)存分配功能提供的虛擬地址空間。在一般情況下,絕大多數(shù)虛擬地址并沒有物理內(nèi)存于它對應,在真正可以使用這些地址空間之前,還要由操作系統(tǒng)提供實際的物理內(nèi)存(這個過程叫"提交"commit)。在不同的情況下,系統(tǒng)提交的物理內(nèi)存是不同的,可能是RAM,也可能是硬盤模擬的虛擬內(nèi)存。3、WIN32中進程間的通訊在Windows95中,為實現(xiàn)進程間平等的數(shù)據(jù)交換,用戶可以有如下幾種選擇:使用內(nèi)存映

5、射文件通過共享內(nèi)存DLL共享內(nèi)存向另一進程發(fā)送WM_COPYDATA消息調(diào)用ReadProcessMemory以及WriteProcessMemory函數(shù),用戶可以發(fā)送由GlobalLock(GMEM_SHARE,.)函數(shù)調(diào)用提取的句柄、GlobalLock函數(shù)返回的指針以及VirtualAlloc函數(shù)返回的指針。3.1、利用內(nèi)存映射文件實現(xiàn)WIN32進程間的通訊Windows95中的內(nèi)存映射文件的機制為我們高效地操作文件提供了一種途徑,它允許我們在WIN32進程中保留一段內(nèi)存區(qū)域,把目標文件映射到這段虛

6、擬內(nèi)存中。在程序?qū)崿F(xiàn)中必須考慮各進程之間的同步。具體實現(xiàn)步驟如下:首先我們在發(fā)送數(shù)據(jù)的進程中需要通過調(diào)用內(nèi)存映射API函數(shù)CreateFileMapping創(chuàng)建一個有名的共享內(nèi)存:HANDLECreateFileMapping(HANDLEhFile,//映射文件的句柄,//設(shè)為0xFFFFFFFF以創(chuàng)建一個進程間共享的對象LPSECURITY_ATTRIBUTESlpFileMappingAttributes,//安全屬性DWORDflProtect,//保護方式DWORDdwMaximumSizeHi

7、gh,//對象的大小DWORDdwMaximumSizeLow,LPCTSTRlpName//必須為映射文件命名);與虛擬內(nèi)存類似,保護方式可以是PAGE_READONLY或是PAGE_READWRITE。如果多進程都對同一共享內(nèi)存進行寫訪問,則必須保持相互間同步。映射文件還可以指定PAGE_WRITECOPY標志,可以保證其原始數(shù)據(jù)不會遭到破壞,同時允許其他進程在必要時自由的操作數(shù)據(jù)的拷貝。在創(chuàng)建文件映射對象后使用可以調(diào)用MapViewOfFile函數(shù)映射到本進程的地址空間內(nèi)。下面說明創(chuàng)建一個名為MyS

8、haredMem的長度為4096字節(jié)的有名映射文件:HANDLEhMySharedMapFile=CreateFileMapping((HANDLE)0xFFFFFFFF),NULL,PAGE_READWRITE,0,0x1000,"MySharedMem");并映射緩存區(qū)視圖:LPSTRpszMySharedMapView=(LPSTR)MapViewOfFile(hMySharedMapFile,F(xiàn)ILE_MAP_READ

當前文檔最多預覽五頁,下載文檔查看全文

此文檔下載收益歸作者所有

當前文檔最多預覽五頁,下載文檔查看全文
溫馨提示:
1. 部分包含數(shù)學公式或PPT動畫的文件,查看預覽時可能會顯示錯亂或異常,文件下載后無此問題,請放心下載。
2. 本文檔由用戶上傳,版權(quán)歸屬用戶,天天文庫負責整理代發(fā)布。如果您對本文檔版權(quán)有爭議請及時聯(lián)系客服。
3. 下載前請仔細閱讀文檔內(nèi)容,確認文檔內(nèi)容符合您的需求后進行下載,若出現(xiàn)內(nèi)容與標題不符可向本站投訴處理。
4. 下載文檔時可能由于網(wǎng)絡(luò)波動等原因無法下載或下載錯誤,付費完成后未能成功下載的用戶請聯(lián)系客服處理。