while(1)循环中互斥对象上的boost scoped_lock
boost scoped_lock on mutex in while(1) loop
我有两个进程,它们共享一个由互斥和条件同步的队列。我的一个进程中有以下代码。
named_mutex mutex(open_only, "MyMutex");
int main()
{
while(1)
{
scoped_lock <named_mutex> lock(mutex)
//do some processing
}
}
我的问题是,互斥体是否在while循环中的所有调用中都具有作用域,还是每次while循环开始时都需要获取它?互斥锁的解锁范围是什么?似乎每次在while循环结束时,互斥对象都会被解锁。
感谢
它的行为与循环体中的任何其他局部变量完全相同:每次迭代都会创建和销毁一次。在这种情况下,它将在每次迭代中锁定和解锁互斥对象一次。
scoped_lock
在创建互斥体时(在其ctor中)锁定互斥体,在删除时(在dtor中)解锁互斥体。
由于lock
实例的作用域在while
主体内,因此互斥体在创建scoped_lock
时被锁定,而在while
循环结束时被解锁:如果找到break
或continue
,甚至是return
语句,或者仅仅当到达while
主体的末尾时,每个循环一次。
相关文章:
- 理解boost::asio-async_read在无需读取内容时的行为
- boost::进程间消息队列引发错误
- 如何运行位于boost/libs/python/example/tutorial目录中的hello.cpp和Jamfil
- cmake如何在fedora工作站中找到boost静态库包
- CMake项目Boost库错误:Boost/config/compiler/gcc.hpp:165:10:致命错误:cs
- Boost Graph Library,修复节点大小
- 什么是"#include <boost/functional/hash.hpp> "?
- 基于boost的程序的静态链接——zlib问题
- C++:如何在CLion IDE中安装Boost
- C++Boost Asio Pool线程,带有lambda函数和传递引用变量
- 如何在boost beast http请求中设置http头
- Boost Spirit,获取迭代器内部语义动作
- boost::asio::steady_timer()与sleep()我应该使用哪一个
- boost::asio如何生成多个协同程序,然后加入它们
- 当我尝试使用 sstream 和分面将 Boost Time_duration转换为字符串时,我没有得到所需的格式
- Visual Studio(或任何其他工具)能否将地址解释为调用堆栈(boost上下文)的开头
- 如何使用boost::具有嵌套结构和最小代码更改的序列化
- 使用Boost Interprocess创建托管共享内存需要很长时间
- Boost::posix_time::ptime舍入到给定的分钟数
- Boost Scoped Ptr-声明与分配