返回一个空的智能指针
Returning an empty smart pointer
我有一个像这样的类,
class A
{
std::shared_ptr<Type> ret;
public:
A()
{
ret=std::shared_ptr<Type>(new Type);
}
std::shared_ptr<Type> GetTypeA(){return ret;}
A (const A&a)
{
....
ret=a.ret;
}
};
class Type
{
A aa;
public:
Type(A*a):aa(*a){}
};
在客户端代码的某处,我像这样调用GetTypeA方法
void func(A*pA)
{
...
std::shared_ptr<Type> spT=pA->GetTypeA();
...
}
调试显示,spT=empty
后调用。但在pA
内部,ret
值不为空
我注意到你代码中的一些错误:
A()
{
ret=std::shared_ptr<Type>(new Type);
}
"new Type"意味着您调用了Type的默认构造函数(Type::Type()),并且您没有在示例中编写它。尝试使用"new Type(*this)"来使用自己的构造函数。但要做到这一点,你需要改变你的类型类为:
class Type
{
A* aa; // Use a pointer
public:
Type::Type(A&a) :aa(&a){} // Use references
};
问题是它没有解决"递归方面",根据您的需要,我会在Type类中使用对a的静态引用…
相关文章:
- 1d 智能指针不适用于语法 (*)++
- 优先顺序:智能指针和类析构函数
- 对于C++中使用智能指针的指针算术限制,有没有一种变通方法
- 智能指针作为无序映射键,并通过引用进行比较
- 智能指针概念所有权和寿命
- 正在理解智能指针,但出现错误:未分配正在释放的指针
- 尝试使用智能指针时引发异常
- 我可以制作指向智能指针的智能指针吗?
- 通过智能指针和转换对基本模板参数进行模板推导
- OpenCV 我应该使用智能指针来防止内存泄漏吗?
- 从堆栈分配的原始指针构造智能指针
- 初始化指向类实例的智能指针并访问其方法
- 如何使用 std::make_shared 创建基类类型的智能指针?
- 给定一个指向堆分配内存的指针,智能指针实现如何为其找到合适的释放函数?
- 编译器不会使用 -std=c++11 编译智能指针
- 具有智能指针的多态性
- C++:矢量分配器行为、内存分配和智能指针
- 在什么情况下,需要共享智能指针而无法使用唯一指针?
- 指向函数签名中的常量智能指针
- 使用智能指针附加的继承对象的深层复制