草庐IT

正点原子

全部标签

【正点原子STM32】STM32初体验(Keil MDK工具下载使用、DAP仿真器、MDK上配置DAP、Debug)

一、MDK5编译例程二、串口下载程序2.1、串口下载程序须知2.2、串口下载硬件连接2.3、配置下载工具(ATK-XISP.exe)2.4、STM32启动模式(M3和M4)三、DAP下载程序3.1、DAP下载硬件连接3.2、在MDK上配置DAP不同开发板的下载算法有所不同Build构建F7、Download下载F8四、DAP调试程序4.1、JTAG/SWD调试原理概述4.2、在MDK配置DAP仿真调试4.3、基础执行控制按钮介绍断点复位、执行控制查看程序段/函数执行时间结束仿真报错解决方法4.4、工具栏常用窗口按钮介绍CallStack窗口(调用栈窗口):查看函数调用关系&局部变量Watch窗

c++ - 多线程中是否需要原子类型? (OS X, clang, c++11)

我试图证明不使用std::atomic是非常糟糕的主意s但我无法创建一个重现失败的示例。我有两个线程,其中一个执行:{foobar=false;}和另一个:{if(foobar){//...}}foobar的类型是bool或std::atomic_bool并初始化为true.我正在使用OSXYosemite,甚至尝试使用this通过CPU亲和性暗示我希望线程在不同的内核上运行的技巧。我在循环等中运行这样的操作,在任何情况下,执行时都没有明显的差异。我最终用clangclang-std=c++11-lstdc++-O3-Stest.cpp检查生成的程序集我看到read上的asm差异很小(

c++ - 由于引用计数器原子递增/递减,shared_ptrs 是否会遇到缓存未命中?

(这可能是原子递增/递减的一般问题,但我在shared_ptrs领域遇到过这种情况)当原子引用计数器递增和递减时,shared_ptr是否遇到两次缓存行未命中/访问?我确实找到了这个:atomicoperationcost但它似乎并没有过于确定......更新:如果我运行一个循环数百万次,递增一个原子变量,我得到的L1缓存未命中率为0.2。如果我对非原子int做同样的事情,我会得到0L1缓存未命中率......测试将暗示L1缓存行正在被逐出。 最佳答案 shared_ptr必须在某处存储引用计数变量。它可能是从堆中分配的,并且sha

c++ - 在 C++ 中访问未初始化的原子私有(private)变量

假设我有以下类(class):classA{public:......voidincrementN(){++n_;}uint64_tgetN(){returnn_;}private:std::atomicn_;......};假设我初始化了类中的所有其他变量,n_除外,并且这不是线程本地存储,因此没有零初始化。我创建了一个类A的对象,并继续调用incrementN()。如果在某个时候我想要n_的值,并且我调用了getN(),这是否会导致load()例程原子n_崩溃? 最佳答案 加载默认使用memory_order_seq_cst。看

c++ - std::atomic 将一对原子 int32 视为一个原子 int64?

我有一对unsignedint32std::atomic_start;std::atomic_end;有时我想通过比较交换来设置开始或结束,所以我不希望在整个64位对上使用CAS可能导致虚假故障。我只想使用32位CAS。_end.compare_exchange_strong(old_end,new_end);现在我可以将开始和结束作为一个64位原子读取来获取。或者两个单独的32位读取。执行一次64位原子提取(编译器添加适当的内存栅栏)而不是使用两个内存栅栏进行两次单独的32原子位读取(或者编译器会优化它吗?)会不会更快?如果是这样,我将如何在C++11中做到这一点?

c++ - 扭曲如何与原子操作一起工作?

warp中的线程在物理上并行运行,所以如果其中一个(称为线程X)启动原子操作,其他线程会做什么?等待?这是否意味着,当线程X被推送到原子队列时,所有线程都将等待,获取访问权限(互斥锁)并使用内存做一些事情,内存受到该互斥锁的保护,然后才是真正的互斥锁?有没有办法让其他线程进行某些工作,比如读取一些内存,这样原子操作会隐藏它的延迟?我的意思是,有15个空闲线程......我猜不太好。Atomic真的很慢,是吗?我怎样才能加速它?有什么模式可以使用它吗?共享内存的原子操作是否锁定银行或整个内存?例如(没有互斥量),有__shared__floatsmem[256];线程1运行atomicA

C++ 原子数组是否也需要是原子的?

我有一些代码如下:KMessageQueue::KMessageQueue(){messages=newatomic[MAX_MESSAGES];for(inti=0;i其中messages是KMessageQueue的成员,定义为:std::atomic*messages;所以消息数组中的每个元素都是原子的,我从另一个线程读取它们。但是数组指针本身也需要是原子的吗?另一个线程会不会在构造函数完成后尝试访问消息,却发现消息还没有被赋值? 最佳答案 Butdoesthearraypointeritselfalsoneedtobeato

C++ 原子列表容器

我正在研究std::atomic但我认为我没有完全理解这个概念。我想知道为什么没有原子容器。所以我玩了一下。首先,我尝试了以下操作:std::atomic>atomicList;但是正如其他一些人已经指出的那样,这是行不通的,因为构造函数是noexcept。所以我创建了一些hack:templateclassMyList{public://MakesurethatnoexceptionisthrownMyList()noexcepttry:l(){}catch(...){}voidpush_back(constT&t){l.push_back(t);}voidpop_front(){l

C++11 原子类和操作——我说得对吗

我的以下假设是否正确:我不需要显式同步对std::atomic的访问来自任何平台上不同线程的对象与我自己的同步对象std::atomic操作可以是无锁的或非无锁的,具体取决于平台std::atomic_bool和std::atomic(以及其他类似的类型)实际上是相同的东西std::atomic_flag是唯一按照标准保证平台无关的无锁操作的类另外,我在哪里可以找到有关std::memory_order的有用信息?以及如何正确使用它? 最佳答案 让我们一一过一遍。我不需要显式同步对std::atomic的访问来自任何平台上不同线程的

C++11 具有非原子变量的原子内存顺序

我不确定c++11中原子变量的内存排序保证如何影响对其他内存的操作。假设我有一个线程定期调用写入函数来更新值,另一个线程调用读取函数来获取当前值。是否保证d=value;的效果不会在a=version;的效果之前看到,而会在b=的效果之前看到版本;?atomica{0};atomicb{0};doubled;voidwrite(intversion,doublevalue){a=version;d=value;b=version;}doubleread(){intx,y;doubleret;do{x=b;ret=d;y=a;}while(x!=y);returnret;}