多态智能指针的使用
Polymorphic smart pointer usage
到目前为止,我有一个函数正在获取类型为IArg
的参数,我可以执行以下操作:
struct IArg
{
};
struct Arg : IArg
{
};
void f (IArg* arg)
{
// do something
}
f(new Arg);
现在,当我得到这个:
void f (std::shared_ptr<IArg> arg)
{
// do something
}
为什么它再次适用于
f(std::make_shared<Arg>());
即使A
和B
相关,std::shared_ptr<A>
和std::shared_ptr<B>
也是不同的类型,对吧?
std::shared_ptr<T>
可从std::shared_ptr<U>
隐式构造,当且仅当U *
可隐式转换为T *
。请参阅cppreference.com
上的构造函数重载(9)。
它之所以有效,是因为std::shared_ptr
有一个临时构造函数,当存在从源指针类型到目标指针类型的隐式转换时,该构造函数才有效。
相关文章:
- 1d 智能指针不适用于语法 (*)++
- 优先顺序:智能指针和类析构函数
- 对于C++中使用智能指针的指针算术限制,有没有一种变通方法
- 智能指针作为无序映射键,并通过引用进行比较
- 智能指针概念所有权和寿命
- 正在理解智能指针,但出现错误:未分配正在释放的指针
- 尝试使用智能指针时引发异常
- 我可以制作指向智能指针的智能指针吗?
- 通过智能指针和转换对基本模板参数进行模板推导
- OpenCV 我应该使用智能指针来防止内存泄漏吗?
- 从堆栈分配的原始指针构造智能指针
- 初始化指向类实例的智能指针并访问其方法
- 如何使用 std::make_shared 创建基类类型的智能指针?
- 给定一个指向堆分配内存的指针,智能指针实现如何为其找到合适的释放函数?
- 编译器不会使用 -std=c++11 编译智能指针
- 具有智能指针的多态性
- C++:矢量分配器行为、内存分配和智能指针
- 通过简单的包装指针C++智能指针性能和差异
- 矢量中的自动指针(智能)
- Std::vector的对象/指针/智能指针传递对象(总线错误:10)