python的進程間通信--共享內存


最近看進程間通信方式,剛好自己也在深入學習python,看到python支持共享內存。所以寫下這篇筆記。

python中,有一個 multiprocessing.shared_memory.SharedMemory類,用來創建和訪問共享內存。

以下是一個例子:

創建共享內存部分,我們使用C代碼,此處參考 大大飛魚老哥的代碼: https://blog.csdn.net/ababab12345/article/details/102931841

 1 #include <stdio.h>
 2 #include <sys/types.h>
 3 #include <sys/stat.h>
 4 #include <fcntl.h>
 5 #include <stdio.h>
 6 #include <sys/mman.h>
 7 #include <string.h>
 8 #include <errno.h>
 9 #include <unistd.h>
10 
11 #define MMAP_DATA_SIZE 1024
12 
13 int main(int argc,char * argv[])
14 {
15     char * data;
16     int fd = shm_open("/shm-file0001", O_CREAT|O_RDWR, 0777);
17     
18     if (fd < 0) {
19         printf("shm_open failed!\n");
20         return -1;
21     }
22     
23     ftruncate(fd, MMAP_DATA_SIZE);
24     
25     data = (char*)mmap(NULL, 1024, PROT_READ|PROT_WRITE, MAP_SHARED, fd, 0);
26     if (!data) {
27         printf("mmap failed\n");
28         close(fd);
29     }
30     
31     
32     sprintf(data,"This is a share memory! %d\n",fd);
33     
34     munmap(data,MMAP_DATA_SIZE);
35     
36     
37     close(fd);
38     getchar();
39     
40     shm_unlink("/shm-file0001");
41     
42     return 0;
43 }
View Code

 

通過xcode編譯運行這段C代碼:

 

 python代碼部分我們只寫一個共享內存的讀取:

1 from multiprocessing import shared_memory
2 
3 if __name__ == '__main__':
4     existing_shm = shared_memory.SharedMemory(name='shm-file0001')
5     content = existing_shm.buf.tobytes()
6     print(content)
7     existing_shm.close()

 

最終python部分代碼運行結果:

 

進一步,class multiprocessing.managers.SharedMemoryManager提供了一種比較方便的管理共享內存的方式。由SharedMemoryManager返回的sharedMemory,在sharedMemoryManager的shutdown()方法被調用后,都會自動清理掉,不用程序員再額外費心了。


免責聲明!

本站轉載的文章為個人學習借鑒使用,本站對版權不負任何法律責任。如果侵犯了您的隱私權益,請聯系本站郵箱yoyou2525@163.com刪除。



 
粵ICP備18138465號   © 2018-2025 CODEPRJ.COM