C++11 智能指针
标签:count 带来 退出 弊端 pre 智能 har uniq 赋值
前言
- 智能指针可以对动态资源进行管理,保证任何情况下,已经构造的对象能够安全的自动销毁。说人话就是防止内存泄漏。
- C++里面共有四个智能指针:auto_ptr、unique_ptr、shared_ptr、weak_ptr,第一个已经C++11抛弃,后三个是c++11所支持。
auto_prt 所有权模式
auto_ptr ap1 (new string ("hello,world"));
auto_ptr ap2;
ap2=ap1
//这里不会报错,ap2剥夺ap1的权限,但程序访问ap1会报错,ap1被废弃。auto_ptr缺点是:存在潜在的程序崩溃问题。
unique_ptr 独占指针
- 独占指针所指向的内存为自己独有,同一时刻只能有一个unique_ptr。指向给定的对象unique_ptr 对象不支持同类赋值和拷贝。
unique_ptr up1(new int(2333));
unique_ptr up2 = up1;//这里会报错,尝试引用已删除的函数。
//将原来up1指向内存交由up3指向
unique_ptr up3 = std::move(up1);
cout up4(new int(2333));
up4.reset(new int(9999));//将原来指向的2333删除掉重新指向9999
cout up5(new int(777));
int* p5 = up5.release();//将内存的控制权交给接受的指针,自己赋值为nullptr,但是没有删除
//cout
shared_ptr 共享指针
- 允许多个该智能指针共享一个堆内存。通过引用计数来实现共同管理和安全释放,只有引用计数为0的时候才会删除该对象的内存,支持赋值和拷贝的
shared_ptr sp1(new int(123));
cout sp2 = sp1;//增加了引用计数
cout sp3(new int(456));
sp2.swap(sp3);//将sp2指向和sp3指向进行了交换,对应的引用计数的变化要清楚
cout sp4 = sp2;
//获取共享指针的原始指针
int* p = sp2.get();
cout sp5 = make_shared();
cout sp6 = make_shared(9527);
cout sp7 = make_shared(10, ‘9‘);
cout
weak_ptr 弱指针
- 主要是为了配合shared_ptr而引入的一种智能指针,只要为了解决循环引用的问题。
- 可以从一个shared_ptr或者另一个weak_ptr对象来构造,但是它的构造和析构不会对引用计数产生实质的影响。
- 并且没有重载*,->这样的指针操作,也就是说weak_ptr对象是没有办法当做指针直接使用的。如果要使用,可以通过lock函数获得一个shared_ptr对象来使用。
shared_ptr aa = make_shared();
shared_ptr bb = make_shared();
//执行结束以后内存没有被释放,循环引用导致的
aa->b = bb;//2
bb->a = aa;//2
//改用弱指针可以消除循环引用的弊端
aa->wb = bb;//1
bb->wa = aa;//1
总结
- 智能指针虽然帮忙管理内存,但是带来程序运行效率的下降。
- 主要根据自己的需求来灵活使用。
C++11 智能指针
标签:count 带来 退出 弊端 pre 智能 har uniq 赋值
原文地址:https://www.cnblogs.com/biu-we/p/13367198.html
评论