码迷,mamicode.com
首页 > 其他好文 > 详细

boost的named_mutex的一些坑

时间:2017-05-09 20:45:16      阅读:306      评论:0      收藏:0      [点我收藏+]

标签:ice   ati   进程启动   解决方案   font   boot   sync   log   proc   

最近遇到一个问题,程序在a用户下运行后,然后注销windows,登陆b用户,发现程序奔溃,抓了下堆栈,发现了boost的named_mutex一些细节,记录下

#include <boost/interprocess/sync/named_mutex.hpp>
#include <boost/interprocess/creation_tags.hpp>
boost::interprocess::named_mutex mutex(boost::interprocess::open_or_create, "haha");
1.这段代码在a用户运行后,注销,在运行b用户,直接崩溃
解决方案
boost::interprocess::permissions per;
per.set_unrestricted();
boost::interprocess::named_mutex mutex(boost::interprocess::open_or_create, "haha",per);
文件中的几个值的意义
UninitializedSegment, //0
InitializingSegment, //1
InitializedSegment, //2
CorruptedSegment //3
定义在boost\interprocess\detail\managed_open_or_create_impl.hpp
开始初始化为1,进程退出的时候改为2
 
2.文件创建在priv_open_or_create函数里面,其中文件夹在create_device里面创建,该函数最终调用
get_last_bootup_time(boost\interprocess\detail\win32_api.hpp) 函数会根据系统的事件来获取启动时间,
如果进程启动之前,系统的日志被一些清理工具清理掉了,那么就会触发异常
 

boost的named_mutex的一些坑

标签:ice   ati   进程启动   解决方案   font   boot   sync   log   proc   

原文地址:http://www.cnblogs.com/ultracpp/p/6832201.html

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!