繁体   English   中英

为什么 boost 的进程间互斥锁在 posix 上不健壮?

[英]Why is boost's interprocess mutex not robust on posix?

我对 boost 很陌生,只是想了解其中的一小部分 - 进程间互斥锁。

AFAIU,在使用文件锁定的跨平台实现中有一个强大的互斥体仿真: http : //www.boost.org/doc/libs/1_62_0/boost/interprocess/detail/robust_emulation.hpp

这是为了模拟 posix 标准中可用的健壮互斥锁,但只有在平台特定版本不可用时才会使用通用方法。

#if !defined(BOOST_INTERPROCESS_FORCE_GENERIC_EMULATION) && defined (BOOST_INTERPROCESS_POSIX_PROCESS_SHARED)
   #include <boost/interprocess/sync/posix/mutex.hpp>
   #define BOOST_INTERPROCESS_USE_POSIX
//Experimental...
#elif !defined(BOOST_INTERPROCESS_FORCE_GENERIC_EMULATION) && defined (BOOST_INTERPROCESS_WINDOWS)
   #include <boost/interprocess/sync/windows/mutex.hpp>
   #define BOOST_INTERPROCESS_USE_WINDOWS
#elif !defined(BOOST_INTERPROCESS_DOXYGEN_INVOKED)
   #include <boost/interprocess/sync/spin/mutex.hpp>
   #define BOOST_INTERPROCESS_USE_GENERIC_EMULATION

但是在实际支持健壮互斥锁的 posix 系统上(我猜这取决于内核版本),健壮互斥锁实际上并未启用。 http://www.boost.org/doc/libs/1_62_0/boost/interprocess/sync/posix/pthread_helpers.hpp

所以我真的不明白这里的逻辑,posix 健壮的互斥体实现是否有任何严重的性能损失,以至于我们不想使用它? 即便如此,至少应该有一个选项可以选择启用此功能。

为了解决这个问题,因为我是菜鸟,所以有什么方法可以使通用实现在 posix 实现上可用,以便我可以利用健壮性?

我刚刚研究了文件 boost/interprocess/sync/posix/pthread_helpers.hpp 中交叉互斥的包装类的 boost 实现。 我看到缺少 PTHREAD_MUTEX_ROBUST。 请添加如下 ROBUST 属性并尝试。

mutexattr_wrapper(bool recursive = false)
 {
         if(pthread_mutexattr_init(&m_attr)!=0 ||
            pthread_mutexattr_setpshared(&m_attr, PTHREAD_PROCESS_SHARED)!= 0 ||
             (recursive &&
              pthread_mutexattr_settype(&m_attr, PTHREAD_MUTEX_RECURSIVE)!= 0 ) ||
              pthread_mutexattr_setrobust(&m_attr, PTHREAD_MUTEX_ROBUST)!= 0)
            throw interprocess_exception("pthread_mutexattr_xxxx failed");
} 

暂无
暂无

声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.

 
粤ICP备18138465号  © 2020-2024 STACKOOM.COM