这段程序使用了 C++ 11 中的线程库(注意:编译时请不要加 -O 优化选项,否则空循环会被优化掉):
g++ -std=c++14 -Wall -pedantic -pthread main.cpp && ./a.out
// mutex::lock/unlock
#include <iostream> // std::cout
#include <thread> // std::thread
#include <mutex> // std::mutex
std::mutex g_mtx; // mutex for critical section
int g_flag = 1;
void thread_run (int id)
{
g_mtx.lock();
++g_flag;
for(int i = 0; i < 100000000; ++i) {}
--g_flag;
std::cout << "thread #" << id << ": " << g_flag << '\n';
g_mtx.unlock();
}
#define NUM_THREAD 9
int main ()
{
std::thread threads[NUM_THREAD];
// spawn NUM_THREAD threads:
for (int i = 0; i < NUM_THREAD; ++i)
threads[i] = std::thread(thread_run, i + 1);
for (auto& th : threads) th.join();
return 0;
}
不使用 mutex 是这样的:
thread #3: 9
thread #1: 8
thread #2: 7
thread #8: 6
thread #4: 5
thread #9: 4
thread #6: 3
thread #7: 2
thread #5: 1
在上面的输出中,为了不让 stdout 成为竞争资源,我们对 stdout 加锁,以防止出现错乱的输出:
void thread_run (int id)
{
++g_flag;
for(int i = 0; i < 100000000; ++i) {}
--g_flag;
g_mtx.lock();
std::cout << "thread #" << id << ": " << g_flag << '\n';
g_mtx.unlock();
}
使用 mutex 是这样的:
thread #1: 1
thread #2: 1
thread #3: 1
thread #5: 1
thread #4: 1
thread #6: 1
thread #7: 1
thread #8: 1
thread #9: 1
C++ 11, C++ 14 可以到这里在线编译:
http://coliru.stacked-crooked.com/