使用boost.thread的时候,记得link到项目中,否则会报找不到的错误。
下面是使用mutex锁的例子
为了防止程序终止,就需要对新建线程调用join方法。join方法是一个阻塞调用:它可以暂停当前线程,直到调用join的线程运行结束。这就使得main函数一直会等待到thread运行结束。
运行结果:(因为是2个线程同时运行,所以结果可能如下)
0
1
2
3
4
5
0
1
2
3
4
5
6
7
8
9
6
7
8
9
下面是使用mutex锁的例子
#include <boost/thread.hpp>
#include <boost/thread/mutex.hpp>
#include <iostream>
boost::mutex io_mutex;
using namespace std;
// 可以试试,将wait(int) 放在不同位置产生的效果
void wait(int seconds)
{
boost::this_thread::sleep(boost::posix_time::seconds(seconds));
}
void hello()
{
for (int i = 0; i < 10; ++i)
{
boost::mutex::scoped_lock lock(io_mutex);
cout << i << endl;
}
}
int main(int argc, char* argv[])
{
// 传递一个工作函数来构造一个工作线程
boost::thread thrd(&hello);
boost::thread thrd2(&hello);
thrd.join();
thrd2.join();
return 0;
}
为了防止程序终止,就需要对新建线程调用join方法。join方法是一个阻塞调用:它可以暂停当前线程,直到调用join的线程运行结束。这就使得main函数一直会等待到thread运行结束。
运行结果:(因为是2个线程同时运行,所以结果可能如下)
0
1
2
3
4
5
0
1
2
3
4
5
6
7
8
9
6
7
8
9