这个系列其实是《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方法,使主线程阻塞直到子线程执行完毕,以免主线程过早结束时销毁所有子线程使线程来不及运行完毕。
就简单解释到这里吧,下回见!
时间: 2024-11-02 11:01:41