在this线程中,建议OP使用mmap()
而不是shmget()
来获取Linux中的共享内存。
我访问了this页面和this页面以获取一些文档,但第二页提供了一个关于mmap()
的模糊示例。
几乎是一个新手,并且需要在两个进程之间共享一些信息(以文本形式),我应该使用shmget()
方法还是mmap()
?为什么?
答案 0 :(得分:71)
这两种方法都是可行的。 mmap
方法比shmget
更具限制性,但更易于使用。 shmget
是旧的System V共享内存模型,具有最广泛的支持。 mmap
/ shm_open
是新的POSIX方式来共享内存并且更易于使用。如果您的操作系统允许使用POSIX共享内存,那么我建议您继续使用它。
一些提示:
fork
创建了自己的孩子,那么mmap
MAP_ANONYMOUS | MAP_SHARED
是最简单的方法 - 只需拨打一个电话。 MAP_ANONYMOUS
是Linux扩展程序not specified by POSIX。shm_open
(+ ftruncate
)+ mmap
与MAP_SHARED
是两个/三个呼叫。某些操作系统需要librt
。/dev/shm/
,则shm_open
相当于在/dev/shm/
中打开文件。答案 1 :(得分:34)
这很大程度上与历史和未来方向有关。
曾几何时,有两个主要(有点竞争)版本的unix - 系统V和BSD。 SysV有自己的IPC版本,包括大型3共享内存,信号量和消息队列。 POSIX来试图团结一致。
所以目前我们有两个版本 - posix共享内存,MQ和信号量以及sysV版本。只是为了让事情变得更混乱,sysV版本也是 posix的一部分。
所以基本上你的问题是你想使用Posix或sysV风格的共享内存吗?一般来说,大多数人都采用长期观点并选择Posix,因为这似乎是通向未来的道路。但是,实际上,sysV的东西是如此嵌入在如此众多的系统中,你必须怀疑它会永远消失。
因此,消除长期的东西,它归结为对您的项目和您的品味有意义的东西。一般来说,sysV版本实际上往往更强大,但它们有一个笨重的界面,大多数人在第一次接触时发现有点困惑。 sysV信号量和消息队列尤其如此。就共享内存而言,可以认为sysV和posix都很尴尬。 sysV版本带有笨重的ftok
和关键内容,而后缀最终需要多次调用和一些竞争条件来设置。从外部来看,posix版本的优势在于它们利用文件系统并且可以使用标准命令行函数(如“rm”)进行维护,而不是依赖于sysV所需的单独的实用程序(例如ipcs
)。 / p>
那你应该使用哪个?作为一项规则,posix版本。但是你应该熟悉sysV版本。它们具有超出posix版本功能的一些功能,您可能希望在特定情况下利用这些功能。