一、智能指针和普通指针混用
一般情况下,我们在写代码时都是要么用智能指针,要么用普通指针,再离谱一点就是智能指针获取普通指针,再去做业务访问操作;
还有一种情况就是,将原有的普通指针,在进行业务代码编写的过程中装载成智能指针,但执行完业务逻辑后,原有的普通指针却还在使用时,就会引发问题;
int *p1 = new int;
{ //块中执行某项业务
std::shared_ptr<int> p2(p1); //此时p1指针已经被管理
}
//此时p2释放,p1也会被释放,p1就会变成空悬指针
cout << *p1; //error p1指向的内存已经被释放,再访问会报内存非法访问
二、智能指针的删除器
template <class U, class D> shared_ptr (U* p, D del);
int *p1 = new int;
{ //块中执行某项业务
std::shared_ptr<int> p2(p1, [](int* p){/*delete p;*/},); //此时p1指针已经被管理, 并设置一个空的指针删除器,离开作用域时不释放指针
}
//此时p2释放,p1不会被释放
cout << *p1; //正常访问了
总之,在原有的业务代码已经写了很多的情况下,最小改动便是如此吧;