weixin_47130646
weixin_47130646
2021-01-24 22:31

C++多线程遇到的入门级别bug

  • c++
#include <iostream>
#include <mutex>
#include <string>
#include <thread>

using namespace std;

std::mutex mu;
void share_print(string msg, int id)
{
	mu.lock();
	cout << msg << " " << id << endl;
	mu.unlock();
}

void func_1()
{
	for (int i = 0; i > -100; i--)
		share_print("From func_1", i);
}

int main()
{
	thread t1(func_1);
	for (int i = 0; i < 100; i++)
		share_print("From main", i);
	t1.join();
}

代码如上,得到的结果如下,按照我的理解,主线程和t1线程分别调用cout函数,但是因为加了mutex锁,这个不应该是主线程和t1线程轮流输出吗,为什么会没有规律呢?谢谢了!!

  • 点赞
  • 回答
  • 收藏
  • 复制链接分享

2条回答