C++11新特性之unique_ptr智能指针

本节继续介绍智能指针,不了解的读者可以先阅读——C++11新特性之shared_ptr智能指针-CSDN博客

1.介绍

        unique_ptr是C++11标准提供的另一种智能指针。与shared_ptr不同的是,unique_ptr指针指向的堆内存无法同其他unique_ptr共享,也就是每一片堆内存空间只能有一个unique_ptr指向。

每个unique_ptr指针指向的堆内存空间的引用计数都只能为1,一旦指针放弃所指堆内存空间,该空间立马释放回收。

2.用法

        unique_ptr智能指针也是以模版类的形式提供的,定义在头文件,并位于std命名空间。在使用中首先要包含这两条语句。

        (1)unique_ptr智能指针的创建

        1.创建空指针。

std::unique_ptr p1();

std::unique_ptr p2(nullptr);

        2.创建具体指向的指针。

std::unique_ptr p3(new int);

 注意,unique_ptr中没有类似make_shared()这样的模版函数

          3.由于unique_ptr不共享内存,因此,没有拷贝构造函数,只有移动构造函数。例如:

std::unique_ptr p4(new int);
std::unique_ptr p5(p4);//错误,堆内存不共享
std::unique_ptr p5(std::move(p4));//正确,调用移动构造函数

        对于调用移动构造函数的 p4 和 p5 来说,p5 将获取 p4 所指堆空间的所有权,而 p4 将变成空指针(nullptr)。

        4.自定义释放规则。和 shared_ptr 指针不同,为 unique_ptr 自定义释放规则,只能采用函数对象的方式。例如:

//自定义的释放规则
struct myDel
{
    void operator()(int *p) {
        delete p;
    }
};
std::unique_ptr p6(new int);

        (2)成员方法

  • operator*()——获取当前 unique_ptr 指针指向的数据。
  • operator->()——重载 -> 号,当智能指针指向的数据类型为自定义的结构体时,通过 -> 运算符获取其内部的指定成员。
  • operator =()——重载了 = 赋值号,从而可以将 nullptr 或者一个右值 unique_ptr 指针直接赋值给当前同类型的 unique_ptr 指针。
  • operator[]()——重载了 [] 运算符,当 unique_ptr 指针指向一个数组时,可以直接通过 [] 获取指定下标位置处的数据。
  • operator bool()——unique_ptr 指针可直接作为 if 语句的判断条件,以判断该指针是否为空,如果为空,则为 false;反之为 true。
  • get()——获取当前 unique_ptr 指针内部包含的普通指针。
  • get_deleter()——获取当前 unique_ptr 指针释放堆内存空间所用的规则。
  • release()——释放当前 unique_ptr 指针对所指堆内存的所有权,但该存储空间并不会被销毁。
  • reset(p)——其中 p 表示一个普通指针,如果 p 为 nullptr,则当前 unique_ptr 也变成空指针;反之,则该函数会释放当前 unique_ptr 指针指向的堆内存(如果有),然后获取 p 所指堆内存的所有权(p 为 nullptr)。
  • swap(x)    交换当前 unique_ptr 指针和同类型的 x 指针。

除此之外,C++11标准还支持同类型的 unique_ptr 指针之间,以及 unique_ptr 和 nullptr 之间,做 ==,!=,<,<=,>,>= 运算。

3.总结 

        unique_ptr对其所指对象拥有唯一所有权,同一时间只能有一个unique_ptr指向同一个对象。当unique_ptr被销毁,其所指对象也会自动销毁。

如有错误,敬请指正!

你可能感兴趣的:(C++11新特性,c++,开发语言)