智能指针与哑指针:多态行为奇特
Smart pointers vs dumb pointers: polymorphism behavior oddity
我正在调试一些更大的代码中的问题,并意识到智能指针及其多态属性有些奇怪。通过简单示例可以最好地看到这一点:
#include <iostream>
#include <memory>
using namespace std;
class A {
public:
virtual void who() {cout << "I am class A" << endl; };
};
class B : public A{
public:
void who() {cout << "I am class B" << endl; };
};
int main(int argc, char *argv[])
{
B b;
A * aptr = &b;
aptr->who(); //Output: I am class B
B * bptr = &b;
bptr->who(); //Output: I am class B
shared_ptr<A> sptr;
sptr = make_shared<A>(b);
sptr->who(); //Output: I am class A
sptr = make_shared<B>(b);
sptr->who(); //Output: I am class B
return 0;
}
前两个输出对我来说很有意义,但是当我初始化的唯一对象是 B 类型时,为什么我可以访问 A 中定义的成员函数(请参阅第三个输出(?从某种意义上说,这是访问派生类型对象的基类成员的一个很好的技巧。然而,这对我来说仍然有点诡异......
谁能解释为什么这种行为可以用智能指针而不是常规指针?
std::make_shared
总是创建一个全新的对象。 那是
sptr = make_shared<A>(b);
更像
A* p1 = new A(b);
而不是像
A* p2 = &b;
p1
和 make_shared
的返回值根本不指向b
。
以下语句:
sptr = make_shared<A>(b);
基本同:
sptr = shared_ptr(new A(b));
您不是从指向B
的指针创建shared_ptr,而是使用 A
的复制构造函数创建一个新的 A
对象。
make_shared<A>(b)
使用b
来构造一个类型为A
的对象,并指向该新构造的对象。这会对B
对象进行切片,因此shared_ptr
真正指向A
。
相关文章:
- 1d 智能指针不适用于语法 (*)++
- 优先顺序:智能指针和类析构函数
- 对于C++中使用智能指针的指针算术限制,有没有一种变通方法
- 智能指针作为无序映射键,并通过引用进行比较
- 智能指针概念所有权和寿命
- 正在理解智能指针,但出现错误:未分配正在释放的指针
- 尝试使用智能指针时引发异常
- 我可以制作指向智能指针的智能指针吗?
- 通过智能指针和转换对基本模板参数进行模板推导
- OpenCV 我应该使用智能指针来防止内存泄漏吗?
- 从堆栈分配的原始指针构造智能指针
- 初始化指向类实例的智能指针并访问其方法
- 如何使用 std::make_shared 创建基类类型的智能指针?
- 给定一个指向堆分配内存的指针,智能指针实现如何为其找到合适的释放函数?
- 编译器不会使用 -std=c++11 编译智能指针
- 具有智能指针的多态性
- C++:矢量分配器行为、内存分配和智能指针
- 通过简单的包装指针C++智能指针性能和差异
- 矢量中的自动指针(智能)
- Std::vector的对象/指针/智能指针传递对象(总线错误:10)