C :为什么此智能指针不可用
C++: Why this Smart Dynamically Pointer are not available?
当我运行B时,一切似乎都可以,但是当我将其交换为A时,它崩溃了,我不知道为什么。
#include <iostream>
#include <vector>
#include <memory>
using namespace std;
int main() {
vector<int> vi(10,5);
auto ptr = make_shared<vector<int>>(vi); //A
// auto ptr = &vi; //B
auto beg = ptr->begin();
while (beg != vi.end())
cout << *beg++ << " ";
return 0;
}
您正在使用ptr->begin()
和vi.end()
。当 *ptr为vi时,那很好,但是您的make_shared<vector<int>>(vi)
行实际上调用复制构造函数并创建了VI的新副本。
如果您确实需要在堆栈中创建一个共享_ptr,则需要这样创建它:
auto ptr = shared_ptr<vector<int>>(&vi, [](vector<int>*){}); //A
这使得共享_ptr是一个空的deleter,因此它不会试图从堆栈中删除任何内容(这会导致崩溃(。
注意:这几乎总是一个坏主意,因为它违反了共享_ptr的全部目的;它不再拥有任何东西。这使情况令人困惑。您需要确保堆栈矢量绝对 的寿命比共享_ptr或您的应用程序崩溃的时间更长。
相关文章:
- 1d 智能指针不适用于语法 (*)++
- 优先顺序:智能指针和类析构函数
- 对于C++中使用智能指针的指针算术限制,有没有一种变通方法
- 智能指针作为无序映射键,并通过引用进行比较
- 智能指针概念所有权和寿命
- 正在理解智能指针,但出现错误:未分配正在释放的指针
- 尝试使用智能指针时引发异常
- 我可以制作指向智能指针的智能指针吗?
- 通过智能指针和转换对基本模板参数进行模板推导
- OpenCV 我应该使用智能指针来防止内存泄漏吗?
- 从堆栈分配的原始指针构造智能指针
- 初始化指向类实例的智能指针并访问其方法
- 如何使用 std::make_shared 创建基类类型的智能指针?
- 给定一个指向堆分配内存的指针,智能指针实现如何为其找到合适的释放函数?
- 编译器不会使用 -std=c++11 编译智能指针
- 具有智能指针的多态性
- C++:矢量分配器行为、内存分配和智能指针
- 通过简单的包装指针C++智能指针性能和差异
- 矢量中的自动指针(智能)
- Std::vector的对象/指针/智能指针传递对象(总线错误:10)