<T> 当 std::atomic<T>::is_always_lock_free 为假时,中断是否安全?
Is std::atomic<T> safe with interrupts when std::atomic<T>::is_always_lock_free is false?
在没有操作系统的嵌入式(ARM(环境中,如果我使用中断,那么使用std::atomic<T>
是否有可能出现死锁?如果是这样,如何?
通常,任何时候都可以中断控制以处理中断。特别是,如果一个人天真地有一个互斥锁,并想用它来对变量做一个"安全",他可能会锁定它,写入和解锁,然后在其他地方锁定,读取和解锁。但是,如果读取处于中断状态,则可以锁定,中断,锁定=>死锁。
特别是,我有一个std::atomic<int>
,is_always_lock_free
正在false
.我应该担心死锁案例吗?当我查看生成的程序集时,编写42
如下所示:
bl __sync_synchronize
mov r3, #42
str r3, [sp, #4]
bl __sync_synchronize
这似乎没有锁定。读取值的 asm 类似。像exchange
这样的更高级操作的(可能的(锁定吗?
__sync_synchronize
只是一个完整的内存屏障的内置。不涉及锁定,因此不会像互斥锁和中断处理程序那样出现死锁。
您使用的是哪种 ARM 内核?在 ARM Cortex-A7 上,以下打印true
两者。
#include <iostream>
#include <atomic>
int main()
{
std::atomic<int> x;
std::cout << std::boolalpha << x.is_lock_free() << std::endl;
std::cout << std::atomic<int>::is_always_lock_free << std::endl;
}
我希望std::atomic<int>
大多数(如果不是全部(在 ARM 上在没有锁的情况下实现,当然从您提供的程序集来看,它似乎没有使用锁。
相关文章:
- 请解释这句话(cout<<1+int((a<b)^((b-a)&1) )<<endl
- 呼叫运营商<<临时
- 如何防止clang格式在流运算符调用之间添加换行符<<
- <<操作员在下面的行中工作
- EASTL矢量<向量<int>>连续的
- C - 创建矢量&lt; vector&lt; double&gt;&gt;矩阵具有分配而不是inizializ
- 为什么将此对向量&lt; map&lt; int,int&gt;&gt;中的地图进行更新.失败
- C :对矢量进行排序&lt; struct&gt;(结构有2个整数)基于结构的整数之一
- 明确的专业化“ CheckIntmap&lt;&gt;”实例化
- 什么是模板&lt;&gt;inline bla bla
- 编辑C Qlist&lt; object*&gt; gt;QML代码和一些QML警告中的模型
- eigen :: llt&lt;eigen :: matrixxd&gt;具有不完整的类型
- 错误,包括&lt; ctype&gt;在原子上使用C 11
- std::vector<;uint8_t>;当C++11/14启用时,手动复制而不是调用memcpy
- 如何加入向量&lt; int&gt;到C 中的单个INT
- 是std :: set&lt; std :: future&gt;不可能存在
- 是numeric_limits&lt; int&gt; :: is_modulo从逻辑上矛盾
- opencv 2.4.7在iOS错误背景_segm.hpp #include&lt; list&gt;未找到
- 在修改列表后,std :: list&lt; t&gt; :: end()的值是否会更改
- ///<评论></评论>在Visual Studio中