线程::get_id (c++ 11)锁是否空闲?
Is thread::get_id (C++11) lock free?
我想测试调用不同函数的线程我的一个类。我有一个临界时间线程,我不希望任何人调用可能从该线程调用new
的函数。然而,由于这两个函数是公共的,我不能通过语言强制执行。
我的想法是测试线程id。假设我可以确保初始化线程id的调用在正确的线程中,我只需要在其他调用中调用thread::get_id()
并与我保存的线程id进行比较。
问题是我也想在关键线程中测试这个ID,但我不能锁定那个线程。
因此我的问题是:thread::get_id()
锁是自由的(什么可能是最糟糕的执行时间)?
对于thread::get_id()
和std::this_thread::get_id()
是否无锁,甚至对于它们的复杂度,标准都没有给出保证。
恐怕你的问题的答案是具体实现的,取决于你的特定标准库和底层线程库。
相关文章:
- 在提升multi_index容器中,是否定义了"default index"?
- 在C++STL中是否有Polyval(Matlab函数)等价物?
- 检查输入是否不是整数或数字
- 是否可以初始化不可复制类型的成员变量(或基类)
- 在C++中,是否可以基于给定的标识符创建基类的新实例,反之亦然
- 是否可以通过C++扩展强制多个python进程共享同一内存
- 此代码是否违反一个定义规则
- 是否需要删除包含对象的"pair"?
- 是否可以从int转换为enum类类型
- 无论条件是否为true,if总是在c++中执行
- 如何找到大小'x'数组是否完全填充,在C++?
- 检查值是否在集合p1和p2中,但不在p3中
- 是否可以在编译时初始化数组,以便在运行时不会花费时间?
- 检查 std::shared_ptr<> 的当前底层类型是否为 T
- 在c++中检查长方体是否尽可能快地重叠(无迭代)
- GL_SHADERSTORAGE_BUFFER位置是否与其他着色器位置冲突
- 子目录是否继承属性,例如add_definitions,include_directories和父Cmakelist.t
- 标准是否使用多余的大括号(例如 T{{{10}}})定义列表初始化?
- C/C++预处理器是否可以检测一些编译器选项
- 是否可以用"iostream"包装现有的TCP/OOpenSSL会话