C++ 智能指针代码解析
前言
如果在程序中使用new从堆分配内存,等到不再需要时,应使用delete将其释放,C++引入了智能指针auto_ptr,以帮助自动完成这个过程,但是aoto_ptr也有其局限性,因此从Boost库中又引入了三种智能指针unique_ptr shared_ptr weak_ptr。
1,aoto_ptr
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 |
|
- output :
003AFBC0
this is ptr!
但是如果输出的是ptr1,程序会如何呢?
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 |
|
崩溃原因: 首先ptr2 = ptr1表示ptr1将访问的权限给了ptr2,同时意味了ptr1已经没有访问字符串的权限,因此会报错。
那如何解决这个问题呢?引入了unique_ptr
2,unique_ptr
1 2 3 4 5 6 7 8 9 10 11 12 13 |
|
unique_ptr 替代auto_ptr实现独占式,可以理解成,同一时刻只能有一个unique_ptr指向给定对象,unique_ptr对象始终是关联的原始指针的唯一所有者。无法复制unique_ptr对象,它只能移动。(这样可以保证,不会出现auto_ptr那样运行时会出现的隐藏内存崩溃问题)
1 2 3 4 5 6 7 8 9 10 |
|
- output:
00D9F8B4
00D9F89C
other unique_ptr
3,share_ptr
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 |
|
- output:
begin...
end...
- share_ptr的循环陷阱
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 |
|
上面这段程序的思路用下面张图可以清晰的表示
图片和代码主要参考的是这篇很棒的博文:智能指针(三):weak_ptr浅析
运行结果后发现并没有调用析构函数释放内存,以后存在内存泄漏的风险
那如何去解决这个问题呢?,可以通过引入weak_ptr来解决,但是weak_ptr需要与share_ptr配合使用
4, weak_ptr
通过在两个类中的一个成员变量改为weak_ptr对象,因为weak_ptr不会增加引用计数,使得引用形不成环,最后就可以正常的释放内部的对象,不会造成内存泄漏
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 |
|
总结
遇到这类新的概念或者方法时,一定要不嫌麻烦的一行一行代码的去敲,在敲的过程中去理解吸收,如果只看不实践,很有可能理解不深刻,无法体会到其中的原理和机制,所以对待问题一定要沉下心来多实践。
