boost并发编程(一)——互斥锁

        这个系列其实是《Boost程序库完全开发指南》的读书笔记。按照书中的方法代码没跑起来,所以转到Ubuntu下学习了。boost库在Ubuntu下的安装,直接用apt-get install命令安装就可以了,需要安装libboost-dev libboost-system libboost-thread

        我们直接上代码,通过讲解代码来学习。一方面,更详细的内容请参看原书,在此不作重复;另一方面,先把代码跑起来比看了半天书连几行代码都运行不起来更能激励学习。

#include <boost/thread.hpp>
#include <boost/thread/mutex.hpp>
#include <string>
#define BOOST_DATE_TIME_SOURCE
#define BOOST_THREAD_NO_LIB

using namespace boost;

int main()
{
    mutex mu;

   {
   		mutex:: scoped_lock lock(mu);
   		thread t1(print, std::string("Hello,"));
   		t1.join();
   }

   {
   		mutex:: scoped_lock lock(mu);
   		thread t2(print, std::string("boost!"));
   		t2.join();
   }

   std::cout << std::endl;

   return 0;
}

mutex是最简单最常用的互斥变量,但如果手工写代码维护互斥锁的状态既繁琐又容易出错,因此boost库提供了一系列RAII型的lock_guard类来自动做这些工作。mutex类中的scope_lock类是其中一种,顾名思义,它的类对象根据作用域来解锁互斥量。在作用域中用一个互斥量来初始化scope_lock对象,互斥量即被锁定;在离开作用域后,会自动调用scope_lock类的析构函数,解锁互斥量。

         thread对象接受一个函数和这个函数的参数作为构造函数的参数来构造线程,这个线程就负责用相应的参数调用指定函数。然后调用thread对象的join方法,使主线程阻塞直到子线程执行完毕,以免主线程过早结束时销毁所有子线程使线程来不及运行完毕。

         就简单解释到这里吧,下回见!


  • 1
    点赞
  • 4
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值