c++11 でスレッドをテストするための簡単なプログラムを作成しましたが、std::cout
期待どおりに動作しません。
class Printer
{
public:
void exec()
{
mutex m;
m.lock();
cout<<"Hello "<<this_thread::get_id()<<endl;
chrono::milliseconds duration( 100 );
this_thread::sleep_for( duration );
m.unlock();
}
};
int main()
{
Printer printer;
thread firstThread([&printer](){
while(1)
printer.exec();
});
thread secondThread([&printer](){
while(1)
printer.exec();
});
firstThread.join();
secondThread.join();
}
結果の一部:
Hello 11376
Hello 16076
Hello 16076
Hello Hello 11376
16076
Hello 11376
,....
スレッドをロックするためにミューテックスを使用したため、2 つのスレッドがstd::cout
同時に実行されている理由がわかりません。何が起こっているのか誰か説明できますか!?