【发布时间】:2021-04-17 08:25:32
【问题描述】:
std::mutex 是非递归的,违反它的是 UB。所以理论上一切皆有可能(包括std::recursive_mutex)),但是libc++ seems to work fine,这个程序输出
再见
#include <iostream>
#include <mutex>
std::mutex m;
int main() {
std::scoped_lock l1(m);
std::scoped_lock l2(m);
std::cout << "bye" << std::endl;
}
这是 libc++ 中的有意设计决定还是只是一些意外(例如,他们可以对 mutex 和 recursive_mutex 使用相同的逻辑)?
libstdc++ 挂起。
注意:我知道人们不应该依赖 UB,所以这不是关于最佳实践,我只是对晦涩的实现细节感到好奇。
【问题讨论】:
-
请考虑您选择的措辞以及“递归”的替代“嵌套”。例如,使用两个不同的互斥锁似乎更好地描述为嵌套,而重复锁定相同的互斥锁可能是“递归的”。还要考虑显示解锁它们的(替代)代码,可能相关的顺序,或者它没有完成。它是否会改变观察到的行为。
-
“似乎工作正常”是 UB 可以做到的。但是,您真正的意思是“在我的机器上使用特定版本的编译器和一组选项似乎可以正常工作”
-
@MarshallClow 我知道,我只是对“工作正常”的原因感到好奇......实际上是我没有在 Godbolt 中使用 -pthread ......愚蠢的错误,但 TIL 的东西......