C :为什么此智能指针不可用

  • 本文关键字:指针 智能 c++ smart-pointers
  • 更新时间 :
  • 英文 :


当我运行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或您的应用程序崩溃的时间更长。

相关内容

  • 没有找到相关文章

最新更新