【发布时间】:2017-06-09 11:34:29
【问题描述】:
为什么这段代码会产生不一致的读取器函数输出?
#include <cstdio>
#include <thread>
#include <mutex>
std::mutex mu;
int i = 0;
void writeThread()
{
for (int j = 0; j < 1000; ++j)
{
std::lock_guard<std::mutex> lock(mu);
printf ("write i: %d\n", ++i);
}
}
void readThread()
{
for (int j = 0; j < 1000; ++j)
printf ("Read i = %d\n", i);
}
int main()
{
std::thread t(writeThread);
std::thread z(readThread);
t.join();
z.join();
return 0;
}
我有时会得到类似的东西:
write i: 996
write i: 997
Read i = 980 <--- wrong reader output starting here
Read i = 998
Read i = 998
write i: 998
Read i = 998
write i: 999
Read i = 999
只是输出错误还是我真的需要在阅读器函数中使用互斥锁?
【问题讨论】:
-
输出有什么问题?如果与作者没有同步,你为什么认为读者应该看到任何特定的价值? (严格来说,这是一个具有完全未定义行为的数据竞赛)。
-
顺便说一下,对于这个例子,你可以使用原子类型,即
std::atomic_int i = 0- 根本不需要互斥体,并且没有数据竞争,尽管你可能仍然看不到你想要的输出. -
这个特殊的例子非常简单。我正在开发的程序读取和写入 STL 和一些更复杂的数据结构。
-
代码存在数据竞争。它的行为是不确定的。
标签: c++ multithreading synchronization