最近看進程間通信方式,剛好自己也在深入學習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 }
通過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()方法被調用后,都會自動清理掉,不用程序員再額外費心了。