草庐IT

atomic-swap

全部标签

c++ - C++ 中的内存模型 : sequential consistency and atomicity

我对C++11中的内存模型有一些疑问。关于https://www.think-cell.com/en/career/talks/pdf/think-cell_talk_memorymodel.pdf29.幻灯片上写着TheC++memorymodelguaranteessequentialconsistency但是,在我之前的帖子中,我了解到C++内存具有弱内存模型-编译器可以根据需要进行重新排序-他必须满足asif规则。 最佳答案 C++内存模型可以保证顺序一致性如果您使用具有适当内存顺序的原子操作来保证顺序一致性。如果您只是使用

c++ - 将 std::atomic_flag 包装在 getter/setter 中是否会使它的 "atomicity"无效?

假设我有一个包含std::atomic_flag作为私有(private)成员的类,通过getter公开。类似于以下内容(伪代码):classThing{private:std::atomic_flagready=ATOMIC_FLAG_INIT;public:isReady(){returnready.test_and_set();}}我天真的问题是:通过方法查询标志是否会将其变成非原子操作,成为非原子函数调用(或者是?)?我是否应该让我的ready标记为公共(public)成员并直接查询它? 最佳答案 不,它没有。test_an

c++ - std::atomic 加载方法在与 std::shared_ptr 一起使用时减少引用计数

我想使用std::atomic在我的代码中,以便可以自动更新shared_ptr,但是在访问shared_ptr时我遇到了问题。atomic上的load()方法似乎减少了shared_ptr上的引用计数,因此我无法在不释放对象的情况下实际使用该对象。这是显示问题的一段简化代码...typedefshared_ptrMyClassPtr;typedefatomicMyClassAtomicPtr;//1.MyClassPtrptr(newMyClass());printf("1.use_count=%d\n",ptr.use_count());//2.MyClassAtomicPtrat

c++ - 错误 C2280 : attempting to reference a deleted function (atomic<int>)

我有一个classA带有成员变量_atomicVar类型std::atomic.#includeclassA{public:A();~A();private:std::atomic_atomicVar;};如果我构建项目,我会收到以下错误:errorC2280:'std::atomic::atomic(conststd::atomic&)':attemptingtoreferenceadeletedfunction我主要是一名C#开发人员,所以我还不了解C++的每个细节(还)。我不知道我在哪里使用atomic的复制代码.我还尝试初始化_atomicVar:std::atomic_ato

c++ - 等待 atomic_bool

我有两个线程和一个由第二个线程设置的标志。我可以使用atomic_bool,但我希望能够等待*在第一个线程上设置标志。我该怎么做?我猜我不能使用condition_variable,因为如果第二个线程在第一个线程开始等待之前调用notify_one,线程将不会唤醒。此外,检查标志是否已经设置应该相当快。我想这应该很简单,但我只是卡住了,所以我在这里问。提前致谢。*编辑:当然是阻塞,而不是忙等待。抱歉,如果不清楚。 最佳答案 在cbreak和Ravadre(注释)的帮助下,我从这里得到:intmain(){std::mutexm;st

c++ - 为什么 SGI STL 不使用 copy-and-swap 习惯用法?

我最近在StackOverflow上阅读了一个关于Whatisthecopy-and-swapidiom?的答案并且知道copy-and-swap习语可以avoidingcodeduplication,andprovidingastrongexceptionguarantee.然而,当我查看SGISTLdequeimplementation,我发现它没有使用成语。我想知道为什么不,如果这个习语在某种程度上像“最佳实践”?deque&operator=(constdeque&__x){constsize_type__len=size();if(&__x!=this){if(__len>=

c++ - 复制赋值运算符应该作为一般规则利用 std::swap 吗?

总是使用std::swap来实现我的复制赋值运算符是一个很好的通用做法吗?我的理解是,这提供了一种共享复制构造函数实现的方法。我想避免复制实际的复制逻辑本身。所以这就是我要做的:classFoo{public:Foo(Fooconst&other){/*assumevalidimplementation*/}Foo&operator=(Fooother){std::swap(*this,other);return*this;}};将“other”传递给赋值运算符的行为执行复制构造(此时我们已经共享了复制逻辑)。我假设交换将调用移动构造(这里有一个编译器生成的实现)。我几乎对每个实现复制

ios - 链接器错误断言失败 : (atom->fixupCount() == 1)

使用Xcode4.0.2,我有一个可以在模拟器中正确编译、链接和运行的目标。但是,当我为iOS设备编译和链接它时,出现以下(完整)链接器错误:Ld/Users/mike/Library/Developer/Xcode/DerivedData/FOObar-ezjrxybxyybadxguvscgaqtaelju/Build/Products/Debug-iphoneos/FrameworkHarness.app/FrameworkHarnessnormalarmv7cd/Users/mike/src/FOO/FOObarsetenvIPHONEOS_DEPLOYMENT_TARGET4

ios - 在没有 MOOV Atom 的情况下识别 MDAT Atom 中的音频样本

我正在尝试通过iOS设备通过RTSP编写实时视频广播。我正在使用AVAssetWriter所以我可以利用硬件编码。要通过RTSP发送,我必须从MOOVblock中获取avcC信息,但是MOOVblock仅在您完成session时从AVAssetWriter写入,当然这还没有完成,因为我正在直播这个。我通过编码、写入、然后完成单个样本缓冲区到文件以及解析文件以获取avcC信息来解决视频的这个问题。效果很好。在直播流之后,由于AVAssetWriter只会写入一个文件,所以我将它写到文件中,然后使用跟踪文件偏移量从该文件中读取。当我仅使用视频执行此操作时,我可以从书面文件中的MDATAto

ios- "swapping"UIViews 可能吗?

这是我的代码:if([pantallasobjectForKey:par]){UIView*vista=[[UIViewalloc]initWithFrame:self.Botones.frame];vista.backgroundColor=[UIColorbrownColor];CGSizela=CGSizeMake(50,60);intcuantos=[part2count];NSArray*arr=[COLGeneralestileN:cuantosRectsOfSize:laintoSpaceOf:vista.framewithMaxPerRow:5spaceVertical