Я использую boost::interpocess::scoped_lock
, используя named_mutex
и timeout
; Я работаю в ОС Linux.
Во время одного из моих тестов у меня произошел сбой: с тех пор, каждый раз, когда я пытаюсь снова запустить приложение, оно застревает в точке, где я создал блокировку; похоже, что мьютекс остался каким-то образом полученным (никакой возможный процесс, использующий его, не запущен).
Кроме того, если вы посмотрите на приведенный ниже код, я ожидаю, что через 150 микросекунд таймер scoped_lock
вернется, чтобы выдать ошибку ... но это не тот случай ... он просто зависает там.
#include <boost/interprocess/sync/named_mutex.hpp>
namespace bi = boost::interprocess;
bi::named_mutex m_mutex;
try{
boost::posix_time::ptime pt(
boost::posix_time::microsec_clock::local_time() ) ;
pt+= boost::posix_time::microseconds( 150 );
bi::scoped_lock< bi::named_mutex > lock( m_mutex, pt );
if( !lock.owns() ){
FATAL( "I didn't acquire the lock." );
return EXIT_FAILURE;
}
....
У меня следующие вопросы:
- Как убедиться, что
boost::interprocess
названный мьютекс уничтожен? (так как увидеть общий мьютекс между процессами и как их уничтожить)
- Почему получение мьютекса не возвращается через 150 микросекунд? Здесь что-то не так в коде ниже?
Большое спасибо
AFG