草庐IT

allocate_shared

全部标签

c++ - 子类和 get_shared_from_this()

我需要找到一个解决方案来允许子类获得其正确的智能指针。classParent:publicenable_shared_from_this{...}classChild:publicParent{publicChild(){boost::shared_ptrpointer=shared_from_this();//shouldworkboost::shared_ptrpointer=shared_from_this();//won'twork....}如何使用shared_from_this()获取正确的智能指针?背景:我正在写一些通知程序/监听器的东西,有些类自然需要从通知程序注册和注

c++ - 如何从 boost 库中取出单个元素(例如 shared_ptr)?

我一直在玩弄一些Boost组件,我认为在我正在从事的项目中唯一直接需要的是boost::shared_ptr。只包含shared_ptr所需的文件会很困难,或者至少只包含Boostsmart_ptr目录的文件到我的项目中?它们似乎对Boost的其他部分有一些外部依赖性-但我认为有一种简单的方法可以只使用Boost库的某些组件,而我错过了它。如果您能告诉我我需要哪些部分或指出一个好的教程,我将不胜感激! 最佳答案 您可以使用bcp工具仅提取所需的header。bcpshared_ptr/foo这会将shared_ptr和所有依赖项复制

C++智能指针enable_shared_from_this

enable_shared_from_this介绍enable_shared_from_this其实是智能指针中的内容,它的作用就是用于在类的内部,返回一个this的智能指针。对于enable_shared_from_this,初学者可能不明白它的使用场景和使用的必要性,可能有得童鞋们会问既然有了this这个指向自己的指针,为什么还需要enable_shared_from_this这个东西呢,直接用this代替不就好了吗?我们来看看以下代码例子,如果先不运行,你能看出什么问题吗?#includeclassPerson{public:Person()=default;~Person(){};st

c++ - boost::shared_ptr 和 std::shared_ptr 共存

我们都知道boost和c++11都支持shared_ptr。有些编译器支持c++11,有些则不支持。我想编写我的代码,以便当编译器支持c++11shared_ptr时,它使用std::shared_ptr;如果没有,请使用boost::shared_ptr。这方面的常见/最佳做法是什么?让我将讨论限制在GCC而不是特定版本。 最佳答案 C++0x/C++11可用性到目前为止,我知道检测GCC是否使用C++0x/C++11的唯一方法是检查预定义宏__GXX_EXPERIMENTAL_CXX0X__:#ifdef__GXX_EXPERI

c++ - shared_ptr 不能为空?

使用std::shared_ptr表示共享所有权和可选性(可能为空)。我发现自己处于这样一种情况,我只想在我的代码中表达共享所有权,而没有任何选择权。当使用shared_ptr作为函数参数时,我必须让函数检查它是否不为null以保持一致/安全。在许多情况下,传递引用而不是当然是一种选择,但有时我也想转让所有权,因为可以使用shared_ptr。是否有一个类可以替换shared_ptr而不可能为空,是否有一些约定来处理这个问题,或者我的问题没有多大意义? 最佳答案 您正在请求not_null包装器类。幸运的是,C++专家已经解决了您的

c++ - 为什么 `std::pmr::polymorphic_allocator` 不会在容器移动时传播?

来自http://en.cppreference.com/w/cpp/memory/polymorphic_allocator:polymorphic_allocatordoesnotpropagateoncontainercopyassignment,moveassignment,orswap.Asaresult,moveassignmentofapolymorphic_allocator-usingcontainercanthrow,andswappingtwopolymorphic_allocator-usingcontainerswhoseallocatorsdonotcomp

c++ - 在基于范围的 for 循环中使用 shared_ptr 到 std::vector

我编写了一个c++函数,它组装一些数据,然后将std::shared_ptr返回到新分配的包含数据的std::vector。类似于此的内容:std::shared_ptr>shared_ptr_to_std_vector_of_ints(){autov=std::make_shared>();for(inti=0;ipush_back(i);returnv;}我尝试使用基于范围的for循环遍历vector的内容,但它表现得好像vector是空的。在摆弄之后,我发现我可以通过将从函数返回的值分配给局部变量,然后在循环中引用它来让它按照我的预期运行://Executesloopzeroti

c++ - 未定义对 avcodec_alloc_context 的引用但 ffmpeg 链接器顺序正确吗?

我想构建静态链接到libavcodec和libavformat的静态链接可执行文件。静态ffmpeg库是用以下方法构建的:./configure--enable-static--enable-gpl--enable-nonfree--disable-vaapi--disable-libopus--prefix=myBuild--disable-swresample链接器设置如下:g++-O2-static-omyBinmyBin-myBin.osomeotherlibraries.a-L/ffmpeg/myBuild/lib-lavformat-lavcodec-lavutil-lrt

c++ - std::make_shared 和 std::make_unique 有 "nothrow"版本吗?

对于new运算符,我们有std::nothrow版本:std::unique_ptrp=new(std::nothrow)T();std::make_shared或std::make_unique有这样的东西吗? 最佳答案 不,我们没有。查看make_unique的cppreference页面和make_shared,我们看到每个版本都使用默认的new重载。实现一个并不难,但是,像这样:templatestd::unique_ptrmake_unique_nothrow(Args&&...args)noexcept(noexcept

C++ 拼图 : Prevent heap allocation for derived classes, 允许自动和静态

目标:Base类的对象可以是静态的、自动的、直接在堆上分配的,并参与在任何地方分配的复合对象对于任何将Base作为可访问祖先的Derived类,对象可以是静态的或自动的并参与组合,但可能不直接在堆上分配例子:#include"Base.h"#include"Derived.h"{staticBasesb;//OKBaseab,*hb=newBase;//OKstaticDerivedsd;//OKDerivedad;//OKDerived*pd=&ad;//OKDerived*hd=newDerived;//Compileerror,linkerror,//test-unitexcep