1
我一个32个内核的计算机上运行下面的程序:互斥和线程独立
#include<iostream>
#include<algorithm>
#include<boost/thread.hpp>
using namespace std;
boost::thread_group g;
boost::mutex _mtx;
class A{
public:
void foo()
{
for(int ix = 0; ix < 10000000; ++ix)
vec.push_back(ix);
sort(vec.rbegin(), vec.rend());
}
private:
vector<int> vec;
};
void thread_fun()
{
A a;
_mtx.lock(); //line 24
a.foo();
_mtx.unlock(); //line 26
}
int main()
{
g.add_thread(new boost::thread(thread_fun));
g.add_thread(new boost::thread(thread_fun)); //line 32
g.join_all();
}
- 随着线24,26和32评论它需要9秒来完成。
- 只有24,26条评论,32条未评论,需要9秒才能完成。
- 由于没有线评论它需要18秒即可完成
我想两个线程是独立的,也不要紧是否有上线a.foo()
或不锁。但它的确如此,为什么?