一、auto_ptr模板
auto_ptr与shared_ptr、unique_ptr都定义了类似指针的对象,可以将new到的地址赋给这一对象,当智能指针过期时,析构函数会调用delete函数,对象将被销毁,由此内存可以自动被释放。
二、shared_ptr模板
先看代码:
auto_ptr p1 (new string("hello world!");
auto_ptr p2;
p2 = p1;
在以上代码中,p1与p2指向同一对象,常规指针在释放内存时,系统会尝试删除同一对象两次。在auto_ptr中,对象的所有权会归于p2,p1将会变为野指针。shared_ptr则允许多个指针指向同一个对象,每多一个指针指向,计数器就会+1,同样在释放的时候,当数值减为0的时候即最后一个指针过期的时候才会调用delete函数。
三、unique_ptr模板
同样为了避免多个指针指向,unique_ptr严格了所有权的概念,即我的就我的,不允许他人指向(如代码段二中,采用unique_ptr编辑将会报错,而原代码会编译通过但可能造成崩溃)。
四、总结
需要多个指针指向一个对象时可使用shared_ptr,如指针数组。不需要多个指针指向一个对象可使用uniq_ptr,uniqu_ptr比auto_ptr更加安全(编译报错远比程序崩溃好得多)。
if(failed(l_hr))
{
return l_hr;
}
//dosomething of itestcomptr
couninitialize();
}
初看这段代码是没有任何问题的,但是运行还是会崩溃.如果我们在
coinitialize(null);下行加上"{"与couninitialize();上行加上"}"就不会出错了.为什么呢?
原因在于原来的coinitialize所开的套间在couninitialize();后已经被关闭.
而智能指针的组件对象却并没有释放,直到程序调用ccomptr<itestcomptr>;的析构函数时才调用
itestcomptr的release方法,但是这时候,套间已经不在了,所以导致了程序的崩溃.在组件
的生命周期很短的时候,智能指针的使用基本是无害的,并且有时是非常方便的.
所以在使用智能指针时有以下建议:
1. 当对象的生命周期很长要小心使用.
2. 当对象的生命周期不确定时不要使用.
3. 千万不要使用全局的智能指针.
if(failed(l_hr)) { return l_hr; } //dosomething of itestcomptr couninitialize(); } 初看这段代码是没有任何问题的,但是运行还是会崩溃.如果我们在 coinitialize(null);下行加上"{"与couninitialize();上行加上"}"就不会出错了.为什么呢? 原因在于原来的coinitialize所开的套间在couninitialize();后已经被关闭. 而智能指针的组件对象却并没有释放,直到程序调用ccomptr的析构函数时才调用 itestcomptr的release方法,但是这时候,套间已经不在了,所以导致了程序的崩溃.在组件 的生命周期很短的时候,智能指针的使用基本是无害的,并且有时是非常方便的. 所以在使用智能指针时有以下建议: 1. 当对象的生命周期很长要小心使用. 2. 当对象的生命周期不确定时不要使用. 3. 千万不要使用全局的智能指针.。
声明:本网站尊重并保护知识产权,根据《信息网络传播权保护条例》,如果我们转载的作品侵犯了您的权利,请在一个月内通知我们,我们会及时删除。
蜀ICP备2020033479号-4 Copyright © 2016 学习鸟. 页面生成时间:2.679秒