c-boost :: named_mutex:在最后一个进程关闭时安全清理
作者:互联网
我有一个资源需要保护在一个流程中以及跨多个流程的访问.我已经通过boost :: interprocess:named_recursive_mutex创建了一个命名互斥体来进行管理,并且效果很好.
#include <boost/interprocess/sync/named_recursive_mutex.hpp>
boost::interprocess::named_recursive_mutex mut(
boost::interprocess::open_or_create, "MY_SHARED_MUTEX_123");
但是,据我了解,最终应通过remove()将其清除,即:
mut.remove("MY_SHARED_MUTEX");
但是,此调用似乎完全破坏了互斥锁,而不是检查/减少引用计数,因此,当我知道没有其他进程在使用它时,我试图寻找一种安全的方法来发出remove()调用.我也可以通过boost创建一块共享内存,但这似乎也没有共享引用计数.
I’ve found a similar question on SO,但是the accepted answer似乎并不能满足我的需要,因为它仅指的是“boost docs”,但是没有明确指示何时可以安全地发出remove().
当我确定访问它的最后一个进程已关闭或可能崩溃时,如何安全地清理此已命名的互斥锁?
谢谢.
解决方法:
据我所知,没有任何引用计数支持.
如果要使用例如Shell脚本启动或停止进程,则可以在启动/停止时从脚本中删除共享内存文件.
如果您有一个始终总是首先启动的进程,则可以使用它在程序启动时删除共享内存文件(或类似地,在程序停止时的最后一个停止进程中).
另一种方法是使用共享内存实现引用计数,最后一个过程将删除所有共享内存文件.但是,如果其中一个进程崩溃,这将无法正常工作,您仍然可以尝试删除segfault信号处理程序,但这可能并不总是有效.
更新:正如@sehe提到的,boost :: interprocess :: shared_ptr可以用于引用计数.
标签:boost-mutex,c,boost,ipc,boost-interprocess 来源: https://codeday.me/bug/20191013/1910372.html