为了更好的理解继承和多态,做一个文本查询的小例子。 接口类:Query有2个方法。 eval:查询,返回查询结果类QueryResult rep:得到要查询的文本 客户端程序的使用方法: 接口类:Query,有一个私有的父类Query_base的智能指针。 父类Query_base有子类WordQu
自C++11开始,STL中引入了智能指针(smart pointer)来动态管理资源,针对使用场景的不同,提供了以下三种智能指针。 unique_ptr unique_ptr是限制最严格的一种智能指针,用来替代之前的auto_ptr,独享被管理对象指针所有权。当unique_ptr对象被销毁时,会在其析构函数内删除关联的原始指针。 unique_ptr对象分为以下两类: ...
一个shared_ptr 对象的内存开销要比裸指针和无自定义 deleter 的 unique_ptr 对象略大。 std::cout << sizeof(int*) << std::endl;//输出8std::cout << sizeof(std::unique_ptr<int>) << std::endl;//输出8std::cout << sizeof(std::unique_ptr<FILE, std::function<void(FILE*)>>) << ...
//方式一:先初始化子类智能指针,然后调用dynamic_pointer_cast转换成基类智能指针对象 std::shared_ptr d1 = std::make_shared(); std::shared_ptr b1 = std::dynamic_pointer_cast(d1); //方式二:先new子类D的指针,然后调用shared_ptr的构造函数初始化基类智能指针 std::shared_ptr b2 = shared_ptr( ...
C++中的智能指针 这部分内容很大部分引用了一个博客,给出链接在最后 在c++中,智能指针一共定义了4种: auto_ptr、unique_ptr、shared_ptr 和weak_ptr。其中,auto_ptr 在C++11已被摒弃,在C++17中已经移除不可用。 首先是为什么要引入智能指针呢?看下一段代码: ClassName *p = new ClassName(); p -> func(...
它主要有如下几种用法:①用于类层次结构中基类(父类)和派生类(子类)之间指针或引用的转换。进行上行转换(把派生类的指针或引用转换成基类表示)是安全的;进行下行转换(把基类指针或引用转换成派生类表示)时,由于没有动态类型检查,所以是不安全的。②用于基本数据类型之间的转换,如把int转换成char,把int转换成enum...
01_C语言提高_day02_14_指针做参数输入输出特性_rec是传智黑马C/C++第13期教程的第382集视频,该合集共计736集,视频收藏或关注UP主,及时了解更多相关视频内容。
独占指针(unique_ptr):独享所有权的智能指针,资源只能被一个指针占有,该指针不能拷贝构造和赋值。但可以进行移动构造和移动赋值构造(调用move() 函数),即一个 unique_ptr 对象赋值给另一个 unique_ptr 对象,可以通过该方法进行赋值。 弱指针(weak_ptr):指向 shared_ptr 指向的对象,能够解决由shared_ptr带来的循...
如果返回动态内存分配的对象或者内存,必须使用指针,引用可能引起内存泄漏。 4.C++中的智能指针 C++里面有四个智能指针:auto_ptr、shared_ptr、weak_ptr、unique_ptr,其中后三个是C++11支持,第一个已经被C++11弃用。 为什么要使用智能指针? 智能指针的作用是管理一个指针,因为存在以下这种情况:申请的空间在函数结束时...
virtual dtor跟普通虚函数一样,基类指针指向子类对象的时候,delete ptr,根据虚函数特征,如果析构函数是普通函数,那么就调用ptr显式(基类)类型的析构函数;如果析构函数是virtual,则会调用子类的析构函数,然后再调用基类析构函数。 避免在构造函数和析构函数里调用虚函数 ...