引子
智能指针在帮助C++程序员管理动态内存方面可谓神兵利器,但是在有些情况下我们想要对数组进行动态内存管理就会发现一个问题 咦?shared_ptr 在默认情况下是不能指向数组的,那是为什么呢。
原因是因为我们的 shared_ptr 默认的删除器是使用 Delete 对智能指针中的对象进行删除,而 delete 要求 new 时是单一指针 Delete时也应该是指针 new时是数组 delete 也应该用数组类型去delete
- shared_ptr
所以我们如果想让我们的 share_ptr 去指向指针 我们只需要去使用一个可调用对象即可 在这种情况下比较常用的函数或者lambda表达式均可
bool del(int *p){
delete [] p;
}
shared_ptr<int> shared(new int[100],del);//使用函数
shared_ptr<int> ptr(new int[100],
[](int *p){delete [] p;});//使用lambda表达式
因为智能指针没有重载下标运算符 意味着我们不能想数组那样去使用这个指针 那怎么样才可以使用呢
shared_ptr 有一个函数可以返回当前智能指针的内置指针的函数 就是成员函数get() 但是我们要注意当智能指针指针已经释放内存以后,get得到的指针就成了空悬指针
有一点需要注意 在我们得到get返回的指针以后,智能指针对象的引用计数其实并没有增加
get() const noexcept
{ return _M_ptr; }
这是get的函数定义
但是如果我们delete从get得到的指针 并不会出现多次delete的错误,现在还不是很理解为什么
我们该如何使用从get中得到的指针呢 其实很简单,就是我们一般的指针操作即可
auto x = ptr.get();
cout << *(x+i) << endl;
注意!!!
其实只是C++11 中不支持而已 C++17中已经支持
- unique_ptr
相比与shared_ptr unique_ptr对于动态数组的管理就轻松多了 我们只需要直接使用即可
unique_ptr<int[]>unique(new int[100]);
而且unique_ptr是重载了下标运算符的,意味着我们可以方便把其当数组一样使用
- Boost C++库
著名的Boost库其实是支持指向数组的,使用方法与unique_ptr差不多
类名为boost::shared_array,定义在<boost/shared_ptr.hpp>
boost::shared_array<int> arr(new int[100]);