基础概念阅读另一篇文章:
C++ 智能指针 : https://blog.csdn.net/qq_28256407/article/details/119377508
unique_ptr支持的操作
p // 将p当做一个条件判断,若p指向一个对象则为true
*p // 解引用p,获得指向它的对象、
p->mem // 等价于 (*p).mem 访问成员
p.get() // 返回p中保存的指针(指向对象的普通指针)。如果智能指针释放了其对象,返回的指针也会被释放
swap(p, q) // 交换p和q中的指针
p.swap(q) // 同上,交换p和q中的指针
unique_ptr<T> u1 // 空的unique_ptr, 可以指向类型为T的对象
unique_ptr<T, D> u2 // u2会使用一个类型为D的可调用对象来释放它的指针
unique_ptr<T, D> u(d) // 空的unique_ptr, 指向类型为T的对象,用类型为D的对象d代替delete
u = nullptr // 释放u指向的对象, 将u置空
u.release() // u放弃对指针的控制权, 返回指针,并将u置空
u.reset() // 释放u指向的对象
u.reset(q) // 如果提供了内置指针q, 令u指向这个对象,否则将u置为空
u.reset(nullptr)
例子:
- 虽然不能拷贝或者赋值unique_ptr,但是我们可以通过release和reset将指针从一个unique_ptr转移到另一个unique_ptr或者shared_ptr
#include <iostream>
#include <memory>
int main()
{
// 定义一个unique指针, 并对其进行开辟空间初始化。
std::unique_ptr<int> u = std::unique_ptr<int>(new int (10));
// 利用内置指针对u2进行初始化
int *a = new int(5);
std::unique_ptr<int> u2(a);
// 将u置空,返回的内置指针,重置u2。【注意】:u已经被置空, u2原来指向的内置指针被释放掉
u2.reset(u.release());
// 将u2置空,并利用返回的内置指针,初始化u3。【注意】:u2被置空
std::shared_ptr<int> u3(u2.release());
}
- 按照自定义的方式,释放是能指针。【注意】: 与shared_ptr不同,定义时需要指明自定义对象的类型。unique_ptr<T, D>
#include <iostream>
#include <memory>
void del(int *ptr)
{
delete ptr;
std::cout << "delete ptr" << std::endl;
}
int main()
{
// 自定义对象化代替delete释放。【注意】: 与shared_ptr不同,定义时需要指明自定义对象的类型
std::unique_ptr<int, decltype(del)*> u(new int(10), del);
std::cout << *u << std::endl;
}