thread_specific_ptr代表了一个全局的变量,而在每个线程中都各自new一个线程本地的对象交给它进行管理。
线程之间就不会因为访问同一全局对象而引起资源竞争导致性能下降。
而线程结束时,这个资源会被自动释放。
例子
1 #include <boost/thread/thread.hpp> 2 #include <boost/thread/mutex.hpp> 3 #include <boost/thread/tss.hpp> 4 #include <iostream> 5 boost::mutex io_mutex; 6 boost::thread_specific_ptr<int> ptr; 7 struct stcount 8 { 9 stcount(int id) : id(id) { } 10 void operator()() 11 { 12 if (ptr.get() == 0) 13 ptr.reset(new int(0)); 14 for (int i = 0; i < 10; ++i) 15 { 16 (*ptr)++; 17 boost::mutex::scoped_lock 18 lock(io_mutex); 19 std::cout << id << ": " << *ptr << std::endl; 20 } 21 } 22 int id; 23 }; 24 25 int _tmain(int argc, _TCHAR* argv[]) 26 { 27 boost::thread thrd1(stcount(1)); 28 boost::thread thrd2(stcount(2)); 29 thrd1.join(); 30 thrd2.join(); 31 while (1); 32 return 0; 33 }