【发布时间】:2020-03-01 18:04:27
【问题描述】:
Visual Studio Professional 2019 项目(版本 16.3.6)中的以下代码会产生警告:
#include <thread>
#include <future>
class Foo {
public:
mutable std::recursive_mutex _writingMutex;
std::recursive_mutex& writingMutex() const { return _writingMutex; }
};
int main()
{
Foo a;
std::lock_guard<std::recursive_mutex> lock(a.writingMutex()); // produces C26110
std::lock_guard<std::recursive_mutex> lock2(a._writingMutex); // no warning
}
第一个锁产生警告C26110:
警告 C26110 调用者在调用函数 'std::lock_guard::~lock_guard' 之前未能持有锁 'lock'
为什么会这样?将互斥体作为参考传递是否不起作用?
【问题讨论】:
-
不能用最近的视觉工作室重现; godbolt.org/z/LEp57M。请提供带有 Visual Studio 版本的minimal reproducible example
-
@AlanBirtles 添加了版本(Visual Studio Professional,16.3.6),并且缺少问题。该项目没有预编译的头文件,是通过 File->New -> Project 新创建的。这是否满足最小可重现示例的要求?
-
会不会是 IntelliJ 的问题?当我激活
/WX(将警告视为错误)时,解决方案仍然可以编译,但“错误列表”窗口显示警告并且代码行有绿色下划线 -
错误码>10000是代码分析错误,不是编译错误。显然,在这种特殊情况下,嵌套锁定会触发误报。向 Microsoft 报告(帮助-> 报告问题...)
-
@rustyx 和 AlanBirtles:感谢您的关注。我根据您的 cmets 回答了我自己的问题
标签: c++ c++11 visual-c++ c++17 std