草庐IT

atomic_shared_ptr

全部标签

c++ - vector<unique_ptr> 使用 push_back 调整大小 - 它是如何工作的?

据我了解,当东西被push_back放入vector时,有时它必须分配一个新的内存块,导致将所有元素从旧内存块复制到其中,调用它们的析构函数。由于unique_ptr析构函数删除了拥有的内存,它们怎么可能与vector一起使用?在vector中使用unique_ptr是否安全?是不是比普通指针慢? 最佳答案 resultingincopyingalltheelementsintoitfromtheoldmemoryblock,callingtheirdestructors.Sinceunique_ptrdestructorsdele

c++ - 我可以使用placement new 来重置shared_ptr 中的对象吗?

假设我有一个类。classBigData{...};typedefboost::shared_ptrBigDataPtr;然后我做:BigDataPtrbigDataPtr(newBigData());稍后在我完成我的对象之后,我确信该对象没有其他用户。执行以下操作是否安全:bigDataPtr->~BigDataPtr();new(&*bigDataPtr)BigData;这会让我在没有任何额外分配的情况下重置对象吗? 最佳答案 有几种方法可以解决这个问题。您可以使用placementnew,这可以保证是安全的,原因有两个:您已经

c++ - 我可以使用placement new 来重置shared_ptr 中的对象吗?

假设我有一个类。classBigData{...};typedefboost::shared_ptrBigDataPtr;然后我做:BigDataPtrbigDataPtr(newBigData());稍后在我完成我的对象之后,我确信该对象没有其他用户。执行以下操作是否安全:bigDataPtr->~BigDataPtr();new(&*bigDataPtr)BigData;这会让我在没有任何额外分配的情况下重置对象吗? 最佳答案 有几种方法可以解决这个问题。您可以使用placementnew,这可以保证是安全的,原因有两个:您已经

【JUC基础】10. Atomic原子类

1、什么是AtomicAtomic英译为原子的。原子结构通常称为不可分割的最小单位。而在JUC中,java.util.concurrent.atomic包是Java并发库中的一个包,提供了原子操作的支持。它包含了一些原子类,用于在多线程环境下进行线程安全的原子操作。使用原子类可以避免使用锁和同步机制,从而减少了线程竞争和死锁的风险,并提高了多线程程序的性能和可伸缩性。2、为什么要使用Atomic这里是JUC专栏,肯定是跟多线程有关系的。我们实现这样一个场景:2个线程对某个数值+1操作,每个线程累加10000次。2.1、传统模式packageatomic;importjava.util.conc

c++ - C++11 中 shared_ptr 的原子操作

通过阅读c++11草案n3242,第20.7.2.5节,看起来我们对shared_ptr进行了原子操作,这使我们能够对复杂结构进行无锁操作,而无需担心GC/内存泄漏。但是,我无法在GCC-4.7.0中成功使用它。我只是测试了以下程序#include#include#includestructX{intx;doubley;std::strings;};intmain(){std::shared_ptrx(newX);autop=std::atomic_load(&x);}它有编译器错误:c.cpp:13:33:error:nomatchingfunctionforcallto‘atomi

c++ - C++11 中 shared_ptr 的原子操作

通过阅读c++11草案n3242,第20.7.2.5节,看起来我们对shared_ptr进行了原子操作,这使我们能够对复杂结构进行无锁操作,而无需担心GC/内存泄漏。但是,我无法在GCC-4.7.0中成功使用它。我只是测试了以下程序#include#include#includestructX{intx;doubley;std::strings;};intmain(){std::shared_ptrx(newX);autop=std::atomic_load(&x);}它有编译器错误:c.cpp:13:33:error:nomatchingfunctionforcallto‘atomi

c++ - 利用 `std::weak_ptr` 实现自杀对象

我正在考虑使用“自杀对象”来模拟游戏中的实体,即能够自行删除的对象。现在,通常的C++03实现(普通的旧deletethis)对可能引用自杀对象的其他对象没有任何作用,这就是我使用std::shared_ptr的原因和std::weak_ptr.现在是代码转储:#include#include#includestructSuObj{SuObj(){std::coutcreate(){std::shared_ptrobj=std::make_shared();return(obj->ptr=std::move(obj));}private:std::shared_ptrptr;};int

c++ - 利用 `std::weak_ptr` 实现自杀对象

我正在考虑使用“自杀对象”来模拟游戏中的实体,即能够自行删除的对象。现在,通常的C++03实现(普通的旧deletethis)对可能引用自杀对象的其他对象没有任何作用,这就是我使用std::shared_ptr的原因和std::weak_ptr.现在是代码转储:#include#include#includestructSuObj{SuObj(){std::coutcreate(){std::shared_ptrobj=std::make_shared();return(obj->ptr=std::move(obj));}private:std::shared_ptrptr;};int

msvcp140_atomic_wait.dll文件丢失如何解决?

其实很多用户玩单机游戏或者安装软件的时候就出现过这种问题,如果是新手第一时间会认为是软件或游戏出错了,其实并不是这样,其主要原因就是你电脑系统的该dll文件丢失了或者损坏了,这时你只需下载这个msvcp140_atomic_wait.dll文件进行安装(前提是找到适合的版本),当我们执行某一个.exe程序时,相应的DLL文件就会被调用,因此安装好之后就能重新打开你的软件或游戏了.那么出现msvcp140_atomic_wait.dll丢失要怎么解决? 一、手动从本站下载dll文件1、从下面列表下载msvcp140_atomic_wait.dll文件32位文件:msvcp140_atomic_w

c++ - std::unordered_map<T,std::unique_ptr<U>> 可复制?海湾合作委员会错误?

g++--version产量:g++.exe(x86_64-posix-seh-rev0,BuiltbyMinGW-W64project)4.9.1Copyright(C)2014FreeSoftwareFoundation,Inc.Thisisfreesoftware;seethesourceforcopyingconditions.ThereisNOwarranty;notevenforMERCHANTABILITYorFITNESSFORAPARTICULARPURPOSE.程序:#include#include#includestatic_assert(!std::is_cop