智能指针的种类以及使用场景

简介: 智能指针的种类以及使用场景

智能指针的种类以及使用场景

踩内存: 由于指针在使用的之前又被释放掉,那么这块内存很有可能又被分配出去了。参考踩内存

  char* p = (char* )malloc(6);
  strcpy(p, "hello");
  free(p);  //当指针p释放内存后,该内存以后可以被存储其他数据
}

free函数就是把这块内存和 p 之间的所有关系斩断,从此 p 和那块内存之间再无瓜葛。至于指针变量p本身保存的地址并没有改变,但是它对这个地址处的那块内存却已经没有所有权了。那块被释放的内存里面保存的值也没有改变,只是再也没有办法使用了。

shared_ptr 使用规范

暴露裸指针:

#include <iostream>
#include <memory>
using namespace std;
int main() {
  int *p = new int();
  shared_ptr<int> sp = shared_ptr<int>(p);  //暴露了裸指针
  shared_ptr<int> sp = shared_ptr<int>(new int);  //隐藏了裸指针
  shared_ptr<int> sp = make_shared<int>(); //其中维护了弱引用技术 
  int *p = sp.get();  //避免使用get方式获取指针
}

智能指针管理的对象将自身返回:

class T : public enable_shared_from_this<int> {
public:
  shared_ptr<T> self() {
    return enable_shared_from_this();
  }
};

unique_ptr 使用规范

//此方式返回是可以的
#include <iostream>
#include <memory>
using namespace std;
class T {};
unique_ptr<T> get_unique() {
  unique_ptr<T> up;
  return up;
}
int main() {
  unique_ptr<T> = get_unique();
  return 0;
}
}

weak_ptr解决循环引用问题

循环引用

#include <iostream>
#include <memory>
using namespace std;
class B;
class A {
public:
  ~A() {
    cout << "A::~A()" << endl;
  }
  shared_ptr<B> spb;
};
class B {
public:
  ~B() {
    cout << "B::~B()" << endl;
  }
  shared_ptr<A> spa;
};
int main() {
  shared_ptr<A> sp1 = make_shared<A>();
  shared_ptr<B> sp2 = make_shared<B>();
  sp1->spb = sp2;
  sp2->spa = sp1;
  cout << "A.use_count():" << sp1.use_count() 
     << " B.use_count():" << sp2.use_count() << endl;
  return 0;
}
//代码运行结果:A.use_count():2 B.use_count():2

利用weak_ptr解决

#include <iostream>
#include <memory>
using namespace std;
class B;
class A {
public:
  ~A() {
    cout << "A::~A()" << endl;
  }
  weak_ptr<B> spb;
};
class B {
public:
  ~B() {
    cout << "B::~B()" << endl;
  }
  weak_ptr<A> spa;
};
int main() {
  shared_ptr<A> sp1 = make_shared<A>();
  shared_ptr<B> sp2 = make_shared<B>();
  sp1->spb = sp2;  //使用了weak_ptr后,在持有的过程中不会增加应用计数
  sp2->spa = sp1;  //使用了weak_ptr后,在持有的过程中不会增加应用计数
  cout << "A.use_count():" << sp1.use_count() << "  B.use_count():" << sp2.use_count() << endl;
  return 0;
}

代码运行结果

A.use_count():1  B.use_count():1
B::~B()
A::~A()
先构造类A对象,在构造类B对象,析构先析构B对象在析构A对象

将引用计数降为 1 ,且调用了各自析构函数。辅助 shared_ptr,用来解决 shared_ptr 循环引用,原理弱引用不占强引用计数

充电站

推荐一个零声学院免费公开课程,个人觉得老师讲得不错,分享给大家Linux,Nginx,ZeroMQ,MySQL,Redis,fastdfs,MongoDB,ZK,流媒体,CDN,P2P,K8S,Docker,TCP/IP,协程,DPDK等技术内容,立即学习


相关文章
|
7月前
|
安全 程序员 编译器
C++中的RAII(资源获取即初始化)与智能指针
C++中的RAII(资源获取即初始化)与智能指针
90 0
|
7月前
|
安全 程序员 C++
C++中的智能指针:从原始指针到现代内存管理
C++中的智能指针:从原始指针到现代内存管理
57 0
|
7月前
|
C++
C++:一文读懂智能指针
C++:一文读懂智能指针
113 0
|
7月前
|
安全 C++ 容器
C++中的智能指针:自动内存管理的利器
C++中的智能指针:自动内存管理的利器
95 0
|
7月前
|
存储 人工智能 编译器
【重学C++】【指针】一文看透:指针中容易混淆的四个概念、算数运算以及使用场景中容易忽视的细节
【重学C++】【指针】一文看透:指针中容易混淆的四个概念、算数运算以及使用场景中容易忽视的细节
113 1
|
7月前
|
存储 Rust C++
C++智能指针
【2月更文挑战第14天】介绍C++智能指针
52 0
|
7月前
|
算法 安全 C++
C++ Effective Modern Pointer (智能指针模块)
C++ Effective Modern Pointer (智能指针模块)
|
7月前
|
安全 C++
C++智能指针的用法
C++智能指针的用法
65 0
|
7月前
|
存储 安全 程序员
c++11智能指针的基本使用
程序员自己管理堆内存可以提高程序的效率,但是管理比较麻烦,使用普通指针,容易造成堆内存泄漏(忘记释放),二次释放问题。
65 0