怎么进行c++智能指针unique_ptr的使用,针对这个问题,这篇文章详细介绍了相对应的分析和解答,希望可以帮助更多想解决这个问题的小伙伴找到更简单易行的方法。
与shared_ptr作用类似,需要解决内存泄漏的问题,但是却不需要使用shared_ptr的引用计数,所以为了减少消耗,就需要一个这样的智能指针。但是使用已被废弃的auto_ptr的话就会有新的问题,auto_ptr在使用过程中如果被拷贝构造或者赋值的话,被复制的auto_ptr就失去了作用,这个时候就需要在auto_ptr的基础上禁用拷贝构造以及赋值操作,也就成了unique_ptr。
一个unique_ptr独享它指向的对象。也就是说,同时只有一个unique_ptr指向同一个对象,当这个unique_ptr被销毁时,指向的对象也随即被销毁。使用unique_ptr需要引入<memory.h>
unique_ptr禁用了拷贝构造以及赋值操作,也就导致了下面的这些操作无法完成。
void testFunction(std::unique_ptr<Test> t){ t->getString(); } void features(){ // Disable copy from lvalue. // unique_ptr(const unique_ptr&) = delete; // unique_ptr& operator=(const unique_ptr&) = delete; //不能进行拷贝构造以及赋值运算,也就表示不能作为函数参数传递 std::unique_ptr<Test> t(new Test); std::unique_ptr<Test> t2 = t; //编译报错 std::unique_ptr<Test> t3(t);//编译报错 testFunction(t);//编译报错 }
void simpleUse(){ Test *test = new Test; std::unique_ptr<Test> t(test); qDebug() << test <<"获取原始指针"<< t.get() <<endl; // t.release(); //释放其关联的原始指针的所有权,并返回原始指针,没有释放对象 // t.reset();// 释放对象 t->getString(); std::unique_ptr<Test> t2 = std::move(t); //交换使用权到t2; t2->getString(); }
和shared_ptr需要注意的地方一样,指向数组时要注意模板书写的方式,以及如何使用自定义删除器
错误写法:会导致内存泄露
void customRemover(){ std::unique_ptr<Test> t(new Test[5]); }
正确写法:
void customRemover(){ std::unique_ptr<Test[]> t(new Test[5]); std::unique_ptr<Test, void(*)(Test *)> p2(new Test[5],[](Test *t){ delete []t; }); }
不要多个unique_ptr指向同一个对象
例如:
void repeatPointsTo(){ Test *test = new Test; std::unique_ptr<Test> t(test); std::unique_ptr<Test> t2(test); //两个unique_ptrzhi'xi指向同一个对象,会导致这个对象被析构两次,导致问题出现 }
会导致对象会被多次析构,导致崩溃
关于怎么进行c++智能指针unique_ptr的使用问题的解答就分享到这里了,希望以上内容可以对大家有一定的帮助,如果你还有很多疑惑没有解开,可以关注亿速云行业资讯频道了解更多相关知识。
免责声明:本站发布的内容(图片、视频和文字)以原创、转载和分享为主,文章观点不代表本网站立场,如果涉及侵权请联系站长邮箱:is@yisu.com进行举报,并提供相关证据,一经查实,将立刻删除涉嫌侵权内容。