我一直在玩弄一些Boost组件,我认为在我正在从事的项目中唯一直接需要的是boost::shared_ptr。只包含shared_ptr所需的文件会很困难,或者至少只包含Boostsmart_ptr目录的文件到我的项目中?它们似乎对Boost的其他部分有一些外部依赖性-但我认为有一种简单的方法可以只使用Boost库的某些组件,而我错过了它。如果您能告诉我我需要哪些部分或指出一个好的教程,我将不胜感激! 最佳答案 您可以使用bcp工具仅提取所需的header。bcpshared_ptr/foo这会将shared_ptr和所有依赖项复制
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
我们都知道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
使用std::shared_ptr表示共享所有权和可选性(可能为空)。我发现自己处于这样一种情况,我只想在我的代码中表达共享所有权,而没有任何选择权。当使用shared_ptr作为函数参数时,我必须让函数检查它是否不为null以保持一致/安全。在许多情况下,传递引用而不是当然是一种选择,但有时我也想转让所有权,因为可以使用shared_ptr。是否有一个类可以替换shared_ptr而不可能为空,是否有一些约定来处理这个问题,或者我的问题没有多大意义? 最佳答案 您正在请求not_null包装器类。幸运的是,C++专家已经解决了您的
我编写了一个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
对于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
根据我所做的研究,这听起来像std::make_shared是构建std::shared_ptr的首选方式。具体是因为:它只执行一次内存分配,而使用new则至少执行两次。如果传递给make_shared的ctor抛出异常,那么它就不会像new那样泄漏。我的问题是,假设我想要一个shared_ptr,我应该总是使用make_shared,还是在某些情况下首选new? 最佳答案 由于计数器和对象共享相同的分配,因此它们也共享相同的释放。计数器必须持续到最后一个shared_ptr和weak_ptr消失。如果您有一个大对象(或许多小对象)
我使用Loki的Functor有一段时间了,最近我问了一个question关于它(仍然没有答案......)有人告诉我使用std::function,但我更喜欢Loki的Functor实现,因为它也可以使用各种指针作为参数(例如std::shared_ptr)。structToto{voidfoo(intparam){std::coutptr=std::make_shared();Loki::Functorfunc(ptr,&Toto::foo);func(1);}有没有办法用std::function做到这一点? 最佳答案 使
以下代码:#include#include#includestructFoo{Foo():m_p(std::make_shared()){}Foo(constFoo&foo){printf("copy\n");}std::shared_ptrm_p;};voidfunc(Foofoo){}intmain(){Foofoo;std::functionf=std::bind(func,foo);printf("usecount:%ld\n",foo.m_p.use_count());f();}得到结果:copycopyusecount:1copy由于复制了Foo,所以我认为m_p的use_
std::unique_ptr有两个模板参数,第二个是要使用的删除器。由于这一事实,我们可以很容易地为unique_ptr添加别名。到需要自定义删除器的类型(例如SDL_Texture),方式如下:usingSDL_TexturePtr=unique_ptr;...哪里SDL2PtrDeleter是一个用作删除器的仿函数。有了这个别名,程序员就可以构造和重置SDL_TexturePtr不关心甚至不知道自定义删除器:SDL_TexturePtrptexture(SDL_CreateTexture(/*args*/));//...ptexture.reset(SDL_CreateTextu