1 Boost.Interprocess 的同步
Boost.Interprocess 允许多个进程同时使用共享内存。因为根据定义,共享内存是在进程之间共享的,Boost.Interprocess 需要支持某种同步。
考虑到同步,我想到了 C++11 标准库或 Boost.Thread 中的类。但是这些类只能用于同步同一进程内的线程;它们不支持不同进程的同步。但是,由于两种情况下的挑战是相同的,因此概念也是相同的。
虽然诸如互斥锁和条件变量之类的同步对象在多线程应用程序中驻留在同一地址空间中,因此可供所有线程使用,但共享内存的挑战是独立进程需要共享这些对象。例如,如果一个进程创建了一个互斥体,它就需要以某种方式从不同的进程中访问。
Boost.Interprocess 提供了两种同步对象:匿名对象直接存储在共享内存中,这使得它们自动可供所有进程使用。命名对象由操作系统管理,不存储在共享内存中,可以通过名称从程序中引用。
Example 33.12. Using a named mutex with boost::interprocess::named_mutex
#