线程消毒剂给出"function race"假阴性
Thread sanitizer gives false negative for "function race"
请考虑以下代码:
#include <atomic>
#include <iostream>
#include <thread>
std::atomic<int> x, y;
std::atomic<int> r1, r2;
void f()
{
r1 = y.load();
x = r1.load();
}
void g()
{
r2 = x.load();
y = 42;
}
int main()
{
x = 0;
y = 0;
r1 = 0;
r2 = 0;
std::thread t1(f);
std::thread t2(g);
t1.join();
t2.join();
std::cout << r1 << " " << r2 << std::endl;
}
- 如果我使用
compilers/linux-x86_64-2.10.1/gnu7.1.0/bin/g++ -fsanitize=thread -O3 -std=c++11 main.cpp -o a.out
编译此代码,TSan
不会提供任何警告和/或线程错误。 - 但是,允许此代码生成
42 0
和0 0
作为输出。- 如果在
f()
启动之前执行g()
,则r1 = y.load()
的值将为42
- 如果在
f()
启动之前未执行g()
,则r1 = y.load()
的值将为0
。
- 如果在
- 这是我应该期待
TSan
抓住的东西,还是我的期望在这里完全错误?- 如果我的期望是错误的,可以做些什么(除了代码检查,这对于较大的代码库来说可能非常困难(来发现这样的错误?
- 如果应该抛出一些错误,是否有一些我可能缺少的特定选项(我正在使用此处文档中指定的所有默认值(?
来自 clang 的文档
ThreadSanitizer是一个检测数据竞争的工具
您没有数据竞争,因为所有变量都是原子的,因此没有什么可报告的。
相关文章:
- "error: no matching function for call to"构造函数错误
- 调用专用模板时出错"no matching function for call to [...]"
- 库函数需要一个 std::function<void(void)>,如何传入类函数?
- Confusion: decltype vs std::function
- 为什么 std::function 可以作为 std::not2 的参数?
- 'max'匹配'std::function<const int &(const int &, const int &)>'无过载
- 传递给std::function template的template参数究竟代表什么
- 将带有unique_ptr的可变 lambda 传递给 const&std::function
- 绑定派生类方法C++从实例范围之外的分隔 std::function 变量调用
- "no matching function for call to 'Vector::Vector'"错误
- 如何在向量中删除 std::function<void()>?
- 不断"Attempting to reference a deleted function"
- 将函数包装器转换为 std::function
- 类型擦除的std::function与虚拟函数调用的开销
- C++ std::function 对于类 exept 的所有实例都是空的(只有 Visual2019 编译器问题)
- 如果模板没有可变参数,则 Lambda 被推导出为 std::function
- 我在 ifstream input_file(文件名)行中收到错误"no matching function to call";
- 模板规范获取'Ambiguous call to overloaded function'
- 将 lambda 表达式传递给 std::function in C++
- 线程消毒剂给出"function race"假阴性