这里有两个类, A和 B, 各有一个虚拟成员函数 sing. B从 A公有继承而来,并且如你所见,工厂函数 createA返回一个动态分配的B的实例,包装在shared_ptr<A>里。在 main里, 一个包含shared_ptr<A>的 std::vector被放入5个元素,最后对每个元素调用sing。如果我们用裸指针作为元素,那些对象需要被手工删除。而在...
了解了C的指针后,理解C++的中的智能指针便不在话下。 数据传递 C语言中有值传递和地址传递的概念。在介绍指针之前,我们先回顾下C语言中这2种数据传递的方式。 值传递:基本数据类型、结构体类型作为函数参数都是值传递。 值传递是简单的数据拷贝,他们的内存地址是不同的。 以函数参数为例,在函数中修改形参的值...
1.智能指针 C++中四种常见的指针:unique_ptr,shared_ptr,weak_ptr,以及C++中已经废弃的auto_ptr。 下面我们根据对象所有权以及对象生命周期分别对这4类进行讲解: 1.auto_ptr auto_ptr要求同时只能有一个指针指向同一个对象,如果有另外一个指针引用了对象,则当前指针引用会被强制抹除置为null_ptr。 模型如下: 案...
a.智能指针的关键技术:在于构造栈上对象的生命期控制 堆上构造的对象的生命期.因为在智能指针的内部,存储 着堆对象的指针,而且在构析函数中调用delete行为. 大致机构如下: x* m_PTRx = new x(100);//#1 template<typename T> auto_ptr{ private: T* m_PTR;//维护指向堆对象的指针,在auto_ptr定位后 ....
说下你对智能指针的理解 因为C++使用内存的时候很容易出现野指针、悬空指针、内存泄露的问题。所以C++11引入了智能指针来管理内存。有四种: auto_ptr:已经不用了 unique_ptr:独占式指针,同一时刻只能有一个指针指向同一个对象 shared_ptr:共享式指针,同一时刻可以有多个指针指向同一个对象 ...
智能指针也是模板类,因此当我们创建一个智能指针是要提供额外的信息——指针可以指向的类型。默认初始化的智能指针保存着一个空指针。shared_ptr允许多个指针指向同一对象。 shared_ptr<string> p1;//可指向stringshared_ptr<list<int>> p2;//可指向int的list ...
最后,一个完备的PIMPL实现会借助unique_ptr类型的智能指针。本例为了简化示例所以采用了裸指针实现,更完整和通用的PIMPL实现可以参见https://en.cppreference.com/w/cpp/language/pimpl。 到此,我们总结一下C/C++语言自身有关符号可见性控制的原则和方法: ...
unique_ptr:c++11版本,独占对所指对象的独有权,不允许其他的智能指针共享其内部的指针,禁止进行拷贝构造和拷贝赋值的操作,但是unique_ptr允许通过函数返回给其他的unique_ptr,还可以通过std::move来把所有权转让到其他的unique_ptr,注意,这时它本身就不再拥有原来指针的所有权了。将一个 unique_ptr 赋值给另一个时...
vector是动态扩容的,2的次方往上翻,为了确保数据保存在连续空间,每次扩充,会将原member悉数拷贝到新的内存块; 不要保存vector内对象的指针,扩容会导致其失效 ;可以通过保存其下标index替代。 运行过程中需要动态增删的vector,不宜存放大的对象本身 ,因为扩容会导致所有成员拷贝构造,消耗较大,可以通过保存对象指针替代...
const char *p 表示 p是指向常量字符串的指针。 char* const p 表示p是指向字符串的常量指针。 2. struct 数据类型对齐: 空成员struct 占一个字节 #pragma pack(n) 设置数值对齐n只能为1 2 4 8 16 struct 整数对齐 若干char类型诺加起来不超过整数倍,则占用一个整数倍 ...