原始指针在放置并推送到智能指针向量时是否会自动转换为智能指针?
Are raw pointers automatically converted to smart pointers when emplaced and pushed to a vector of smart pointers?
我偶然发现了这样的代码:
std::vector<std::unique_ptr<Fruit>> fruits;
fruits.emplace_back(new Fruit);
(从这里开始(
所以在代码中,我们有一个原始指针(new
产生一个原始指针,对吧?(被推入一个唯一指针的向量中。代码有效!但是为什么?
因为这不会编译:
std::unique_ptr<Fruit> f = new Fruit();
为了方便起见,是不是有点底层的魔法?
另外,这种方法而不是显式fruits.emplace_back(std::make_unique<Fruit>())
可能存在的陷阱是什么?我读过make_unique
是创建唯一指针的首选方法。
代码有效!但是为什么?
vector::emplace_back
获取参数列表,并将它们转发到它创建的元素的构造函数。
unique_ptr<Fruit>::unique_ptr(Fruit*)
是一个构造函数,它获得传递的裸指针的所有权。
另外,这种方法而不是 [
make_unique
] 可能有哪些陷阱
最大的陷阱是emplace_back
可能会引发异常,在这种情况下,尚未成功创建unique_ptr
。在这种情况下,传递给emplace_back()
的分配对象将被泄漏。因此,传递unique_ptr
而不是裸指针更可取,以便原始指针始终归某人所有。
关于使用new
而不是一般std::make_unique()
的小问题:它使程序"不平衡",阻止您使用古老的经验法则"delete
与您new
的指针一样多"来推理程序的正确性。在这种情况下,您有一个正确的程序,其new
多于delete
。这是否是一个问题,是个人意见的问题。
std::unique_ptr<Fruit> f = new Fruit();
不起作用,但
std::unique_ptr<Fruit> f{new Fruit()};
工程。第一个不起作用,因为从语法上讲,它使用副本初始化。复制初始化不适用于std::unique_ptr
,因为接受指针作为参数的构造函数explicit
。
fruits.emplace_back(new Fruit);
由于上面使用的构造函数的存在而起作用。
- 1d 智能指针不适用于语法 (*)++
- 优先顺序:智能指针和类析构函数
- 对于C++中使用智能指针的指针算术限制,有没有一种变通方法
- 智能指针作为无序映射键,并通过引用进行比较
- 智能指针概念所有权和寿命
- 正在理解智能指针,但出现错误:未分配正在释放的指针
- 尝试使用智能指针时引发异常
- 我可以制作指向智能指针的智能指针吗?
- 通过智能指针和转换对基本模板参数进行模板推导
- OpenCV 我应该使用智能指针来防止内存泄漏吗?
- 从堆栈分配的原始指针构造智能指针
- 初始化指向类实例的智能指针并访问其方法
- 如何使用 std::make_shared 创建基类类型的智能指针?
- 给定一个指向堆分配内存的指针,智能指针实现如何为其找到合适的释放函数?
- 编译器不会使用 -std=c++11 编译智能指针
- 具有智能指针的多态性
- C++:矢量分配器行为、内存分配和智能指针
- 通过简单的包装指针C++智能指针性能和差异
- 矢量中的自动指针(智能)
- Std::vector的对象/指针/智能指针传递对象(总线错误:10)