当前位置:  开发笔记 > 编程语言 > 正文

创建一个shared_ptr向量的向量

如何解决《创建一个shared_ptr向量的向量》经验,为你挑选了1个好方法。

尝试创建shared_ptr到int的向量.

我哪里错了?谢谢.基思:^)

#include 
#include 
#include 

int main() {
    std::vector > w;
    std::vector >::iterator it_w;
    w.push_back(new int(7));

    std::cout << std::endl;
}

编译结果:

pickledegg> g++ -std=c++11 -o shared_ptr shared_ptr.cpp
shared_ptr.cpp:29:4: error: no matching member function for call to 'push_back'
        w.push_back(new int(7));
        ~~^~~~~~~~~
/Applications/Xcode.app/Contents/Developer/Toolchains/XcodeDefault.xctoolchain/usr/bin/../include/c++/v1/vector:697:36: note: 
      candidate function not viable: no known conversion from 'int *' to 'const value_type' (aka
      'const std::__1::shared_ptr') for 1st argument
    _LIBCPP_INLINE_VISIBILITY void push_back(const_reference __x);
                                   ^
/Applications/Xcode.app/Contents/Developer/Toolchains/XcodeDefault.xctoolchain/usr/bin/../include/c++/v1/vector:699:36: note: 
      candidate function not viable: no known conversion from 'int *' to 'value_type' (aka
      'std::__1::shared_ptr') for 1st argument
    _LIBCPP_INLINE_VISIBILITY void push_back(value_type&& __x);
                                   ^
1 error generated.

François And.. 9

std::shared_ptr接受原始指针的构造函数被标记为显式.来源.您将无法调用push_back与原始指针,因为它不是隐式转换为std::shared_ptr这正是push_back需要作为参数.解决方案是使用emplace_back代替push_back或使用std::make_shared.

emplace_back 匹配给予T的构造函数之一的参数.

w.emplace_back(new int(7));

std::make_shared返回一个类型的对象std::shared_ptr,避免这个问题.

w.push_back(std::make_shared(7));

您可以组合这些解决方案.

#include 
#include 
#include 

int main(int argc, char** argv) {
    std::vector > w;
    std::vector >::iterator it_w;
    w.emplace_back(std::make_shared(7));

    std::cout << std::endl;
}

编辑:作为一个附加的注释,总是喜欢std::make_shared(...)std::shared_ptr(new T(...)).它旨在避免非常微妙的潜在内存泄漏.它还优雅地避免了new没有delete它可能会打扰某些人的情况.

编辑2:此外,它std::make_shared(...)有一个性能优势,它避免在`std :: shared_ptr(new T(...))中的额外分配' 看到这个答案.



1> François And..:

std::shared_ptr接受原始指针的构造函数被标记为显式.来源.您将无法调用push_back与原始指针,因为它不是隐式转换为std::shared_ptr这正是push_back需要作为参数.解决方案是使用emplace_back代替push_back或使用std::make_shared.

emplace_back 匹配给予T的构造函数之一的参数.

w.emplace_back(new int(7));

std::make_shared返回一个类型的对象std::shared_ptr,避免这个问题.

w.push_back(std::make_shared(7));

您可以组合这些解决方案.

#include 
#include 
#include 

int main(int argc, char** argv) {
    std::vector > w;
    std::vector >::iterator it_w;
    w.emplace_back(std::make_shared(7));

    std::cout << std::endl;
}

编辑:作为一个附加的注释,总是喜欢std::make_shared(...)std::shared_ptr(new T(...)).它旨在避免非常微妙的潜在内存泄漏.它还优雅地避免了new没有delete它可能会打扰某些人的情况.

编辑2:此外,它std::make_shared(...)有一个性能优势,它避免在`std :: shared_ptr(new T(...))中的额外分配' 看到这个答案.

推荐阅读
吻过彩虹的脸_378
这个屌丝很懒,什么也没留下!
DevBox开发工具箱 | 专业的在线开发工具网站    京公网安备 11010802040832号  |  京ICP备19059560号-6
Copyright © 1998 - 2020 DevBox.CN. All Rights Reserved devBox.cn 开发工具箱 版权所有