进程间通讯有多种方式,包括信号,管道,消息队列,信号量,共享内存,socket等,本文使用python模块mmap做一个进程间通讯的演示。
mmap模块支持windows和Unix系统,但有差别,针对不同的操作系统提供不同的构造函数,本文在windows环境下进行。因此只介绍windows下如何使用共享内存进行进程间通讯的。
windows下的共享内存是可以进行命名的,并且该共享内存在当前环境下所有进程都是可以访问。windows下mmap的构造函数声明如下:
class mmap.mmap(fileno, length[, tagname[, access[, offset]]])
fileno参数表上映射的文件,如果是共享内存的话,该参数传递-1,length参数表上内存的大小,我们的实例是1024(1K)。tagname参数就是共享内存的名称了,为了在其他进程中能够共享该内存,因此这里命名为“share_mmap”,access参数用于限制对共享内存的访问,其取值为ACCESS_READ, ACCESS_WRITE和ACCESS_COPY的一个,offset表示内存偏移量。
本文的实例,创建两个应用程序,一个用于往共享内存中写一些字符串,另一个进程读取共享内存中的内容。为了方便,这里使用Tkinter Gui框架,因为这是python内置的,不需要安装第三方的GUI库,如QT或wxPython等。代码如下是写共享内存的应用程序:
# write_app.py
import mmap
from Tkinter import *
clas