(C智能指针详解.docxVIP

  1. 1、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。。
  2. 2、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载
  3. 3、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
  4. 4、该文档为VIP文档,如果想要下载,成为VIP会员后,下载免费。
  5. 5、成为VIP后,下载本文档将扣除1次下载权益。下载后,不支持退款、换文档。如有疑问请联系我们
  6. 6、成为VIP后,您将拥有八大权益,权益包括:VIP文档下载权益、阅读免打扰、文档格式转换、高级专利检索、专属身份标志、高级客服、多端互通、版权登记。
  7. 7、VIP文档为合作方或网友上传,每下载1次, 网站将根据用户上传文档的质量评分、类型等,对文档贡献者给予高额补贴、流量扶持。如果你也想贡献VIP文档。上传文档
查看更多
(C智能指针详解

C++?智能指针详解?一、简介由于?C++?语言没有自动内存回收机制,程序员每次?new?出来的内存都要手动?delete。程序员忘记?delete,流程太复杂,最终导致没有?delete,异常导致程序过早退出,没有执行?delete?的情况并不罕见。用智能指针便可以有效缓解这类问题,本文主要讲解参见的智能指针的用法。包括:std::auto_ptr、boost::scoped_ptr、boost::shared_ptr、boost::scoped_array、boost::shared_array、boost::weak_ptr、boost::intrusive_ptr。你可能会想,如此多的智能指针就为了解决new、delete匹配问题,真的有必要吗?看完这篇文章后,我想你心里自然会有答案。?下面就按照顺序讲解如上?7?种智能指针(smart_ptr)。?二、具体使用1、总括对于编译器来说,智能指针实际上是一个栈对象,并非指针类型,在栈对象生命期即将结束时,智能指针通过析构函数释放有它管理的堆内存。所有智能指针都重载了“operator-”操作符,直接返回对象的引用,用以操作对象。访问智能指针原来的方法则使用“.”操作符。访问智能指针包含的裸指针则可以用?get()?函数。由于智能指针是一个对象,所以if (my_smart_object)永远为真,要判断智能指针的裸指针是否为空,需要这样判断:if (my_smart_object.get())。智能指针包含了?reset()?方法,如果不传递参数(或者传递?NULL),则智能指针会释放当前管理的内存。如果传递一个对象,则智能指针会释放当前对象,来管理新传入的对象。我们编写一个测试类来辅助分析:class Simple {?public:?Simple(int param = 0) {?number = param;?std::cout Simple: number std::endl;??}??~Simple() {?std::cout ~Simple: number std::endl;?}??void PrintSomething() {?std::cout PrintSomething: info_extend.c_str() std::endl;?}??std::string info_extend;?int number;};?2、std::auto_ptrstd::auto_ptr?属于?STL,当然在?namespace std?中,包含头文件?#includememory?便可以使用。std::auto_ptr?能够方便的管理单个堆内存对象。我们从代码开始分析:void TestAutoPtr() {std::auto_ptrSimple my_memory(new Simple(1));//?创建对象,输出:Simple:1if (my_memory.get()) {//?判断智能指针是否为空my_memory-PrintSomething();//?使用?operator-?调用智能指针对象中的函数my_memory.get()-info_extend = Addition;//?使用?get()?返回裸指针,然后给内部对象赋值my_memory-PrintSomething();//?再次打印,表明上述赋值成功(*my_memory).info_extend += other;//?使用?operator*?返回智能指针内部对象,然后用“.”调用智能指针对象中的函数my_memory-PrintSomething();//?再次打印,表明上述赋值成功?}}// my_memory?栈对象即将结束生命期,析构堆对象Simple(1)执行结果为:Simple: 1PrintSomething:PrintSomething: AdditionPrintSomething: Addition other~Simple: 1上述为正常使用?std::auto_ptr?的代码,一切似乎都良好,无论如何不用我们显示使用该死的delete?了。?其实好景不长,我们看看如下的另一个例子:void TestAutoPtr2() {?std::auto_ptrSimple my_memory(new Simple(1));?if (my_memory.get()) {?std::auto_ptrSimple my_memory2;//?创建一个新的?my_memory2?对象?my_memory2 = my_memory;//?复制旧的?my_memory?给?my_memory2?my_memory2-PrintSomething();//?输

文档评论(0)

64348377 + 关注
实名认证
文档贡献者

该用户很懒,什么也没介绍

1亿VIP精品文档

相关文档