草庐IT

正点原子

全部标签

c++ - 为什么 C/C++ 编译器并不总是使++ 成为原子?

如题,当我们在C/C++中编写++a时,编译器似乎可能将其编译为:incdwordptr[i]这是原子的,或者:moveax,dwordptr[i]inceaxmovdwordptr[i],eax这不是原子的。将其编译为非原子样式有什么好处吗? 最佳答案 如果您的代码看起来像这样怎么办?++a;if(a>1){...}如果编译器使用第一种表示,它会访问内存以递增a,然后再次访问内存以与1进行比较。在第二种情况下,它访问内存一次获取值并将其放入eax。然后它简单地将寄存器eax与1进行比较,这明显更快。

正点原子IMX6ULL-Linux驱动开发

目录第一期第6讲Ubuntu终端操作与Shell命令 第一期第8讲Ubuntu文件系统结构 第一期第9讲Ubuntu磁盘管理 第一期第10讲Ubuntu压缩与解压缩 第一期第11讲Ubuntu用户和用户组  第一期第12讲Ubuntu文件权限第一期第13讲Linux连接文件 第一期第14讲vim编辑器 第一期第16讲make工具和Makefile引入第一期第17讲Makefile基本语法 第一期第18讲Shell脚本 第一期第19讲Shell脚本入门第一期第6讲Ubuntu终端操作与Shell命令  第一期第8讲Ubuntu文件系统结构  第一期第9讲Ubuntu磁盘管理 拔掉U盘看看哪个设备

c++ - 原子 vector 完全线程安全?

我有一个std::vector>vec。运行安全吗vec[index].fetch_add(1,std::memory_order_release)或在其上存储/加载多个并发线程?我认为应该是这样,因为读取是线程安全的,并且由于原子性,不可能同时从多个线程写入一个条目-对吗? 最佳答案 不,一般来说,它不是线程安全的,因为容器本身不是原子的。也就是说,只要您不更改vector中的内容(即做任何使data()的返回无效的事情),您就没事。遗憾的是你不能求助于std::atomic>作为std::vector不是可简单复制。

c++ - 原子地 std::vector::push_back() 并返回索引

我需要创建一个函数,将一个值附加到vector并返回刚刚附加的值的索引。例子:intappend(std::vector&numbers,intnumber){intretval=numbers.size();//whatifsomeotherthreadcallspush_back(number)inbetweenthesecalls?numbers.push_back(number);returnretval;}我想以原子方式执行此操作,以便返回的索引始终正确,即使可能有多个线程将值附加到vector。如果push_back返回刚刚添加的项目的索引,那会很容易。如何保证返回正确的索

C++11 原子 x86 内存排序

在C++0x中原子变量的文档之一中,在描述内存顺序时,它提到:Release-AcquireOrderingOnstrongly-orderedsystems(x86,SPARC,IBMmainframe),release-acquireorderingisautomatic.NoadditionalCPUinstructionsareissuedforthissynchronizationmode,onlycertaincompileroptimizationsareaffected...首先,x86遵循严格的内存排序是真的吗?总是强加这一点似乎效率很低。意味着每次写入和读取都有一个

c++ - C++中的原子指针和线程间传递对象

我的问题涉及std::atomic以及这个指针指向的数据。如果在线程1中我有ObjectA;std:atomicptr;intbar=2;A.foo=4;//fooisanint;ptr.store(*A);如果在线程2中我观察到ptr指向A,我能保证ptr->foo是4和bar是2吗?原子指针的默认内存模型(顺序一致)是否保证在原子存储之前发生的非原子(在本例中为A.foo)上的分配将在其他线程看到分配之前被其他线程看到同样atomic.store对于这两种情况?如果有帮助或重要,我正在使用x64(我只关心这个平台)、gcc(具有支持原子的版本)。 最佳答

【正点原子STM32】STM32时钟系统(时钟树、时钟源、分频器和倍频系数、锁相环、STM32CubeMX时钟树、系统时钟配置步骤)

一、认识时钟树1.1、什么是时钟?1.2、认识时钟树(F1)1.3、认识时钟树(F4)1.4、认识时钟树(F7)1.5、认识时钟树(H7)二、配置系统时钟2.1、系统时钟配置步骤2.2、外设时钟使能和失能2.3、sys_stm32_clock_init函数(F1)HAL_RCC_OscConfig()函数(F1)HAL_RCC_ClockConfig函数(F1)2.4、sys_stm32_clock_init函数(F4/F7)HAL_RCC_OscConfig()函数(F4/F7)HAL_RCC_ClockConfig()函数(F4/F7)2.5、sys_stm32_clock_init函数(

c++ - 大量文件的原子删除

我正在尝试一次性删除10000多个文件,例如要么全部都需要立即删除,要么都需要留在原地。当然,显而易见的答案是将所有文件移动到一个临时目录,并在成功时递归删除它,但这会使所需的I/O量加倍。压缩不起作用,因为1)我不知道需要删除哪些文件,以及2)文件需要经常编辑。有什么可以帮助降低I/O成本的方法吗?任何平台都可以。编辑:我们假设随时可能发生停电。 最佳答案 Kibbee是正确的:您正在寻找交易。但是,如果您不想,则不必依赖数据库或特殊的文件系统功能。交易的本质是这样的:将一条记录写入一个特殊文件(通常称为“日志”),列出您要删除的

c++ - 标准::原子 | compare_exchange_weak 与 compare_exchange_strong

我不确定是我不理解还是文档没有明确制定。以下摘自最新草案(N3126,第29.6节):boolatomic_compare_exchange_weak(volatileA*object,C*expected,Cdesired);boolatomic_compare_exchange_weak(A*object,C*expected,Cdesired);boolatomic_compare_exchange_strong(volatileA*object,C*expected,Cdesired);boolatomic_compare_exchange_strong(A*object,C*

c++ - 包装原子类型并确保它保持原子性

我有一个有点独特和有趣(而且很糟糕)的场景,它迫使我做一些棘手的事情。问题如下:我们需要一个原子类型来在实时线程和后台加载线程之间进行无锁同步。类型(不幸的是)必须编译:一个。QNX只有c++03,但支持boost::atomic。具有c++11但无法构建boost::atomic的Nucleus这迫使我考虑同时使用boost::atomic和std::atomic。我处理这个问题的方法是生成一个新类型,将所有功能转发给平台上相关的atomic类型。这个想法是这样的:原子.hppnamespaceosal{namespacedetail{templateclassTAtomic>str