从函数返回shared_ptr
return shared_ptr from function
我有一个class,它返回std::shared_ptr,也就是Product_SPTR:
Product_SPTR Mill::Production(sf::Time time)
{
if(m_isProducing)
{
if(elapsedTime.getElapsedTime()>m_manufacturingTime)
{
elapsedTime.restart();
Flour_SPTR a(new Flour(5,1,ProductType::CONSTRUCTION),deleter<Flour>);
return a ;
}
}
}
那么我有typedef std::vector<Product_SPTR> VectorProduct_SPTR
当我试图将新的Product_SPTR添加到向量时,我有segmentation fault
此处:
products.push_back(a->Production(gameTime.getElapsedTime()));
但当我做这样的事情时:
products.push_back(new Flour(5,1,ProductType::CONSTRUCTION),deleter<Flour>);
不会出现问题。。。。
我刚开始使用智能指针,所以也许我不知道如何使用它。。
当两个if
中的条件都计算为false
时,您错过了一个return
语句。它进行编译,可能会向您发出编译器警告。除非您了解警告及其含义,否则您应始终在最高警告级别上工作,并逐一消除所有警告。
另外,不是写
Flour_SPTR a(new Flour(5, 1, ProductType::CONSTRUCTION),deleter<Flour>);
return a;
你可能应该写
return Flour_SPTR(new Flour(5, 1, ProductType::CONSTRUCTION), deleter<Flour>);
现代编译器在优化冗余变量方面应该没有任何问题,但帮助编译器完成它的工作总是很好的。如果你可以跳过deleter,你也可以写:
return std::make_shared<Flour>(5, 1, ProductType::CONSTRUCTION);
相关文章:
- CLANG 编译器 说:变量"PTR"可能未初始化
- 在以唯一ptr为值的C++映射中,动态内存何时会被销毁
- 将 ptr 传递给 ptr 到 A 作为参数传递给 A 的函数是不好的做法吗?
- 为共享 ptr 向量实现复制 c'tor?
- 字符和整数中 **(ptr+1) 的值差异
- C++:在不中断共享的情况下通过引用传递共享 PTR?
- 如何将派生类从基 ptr 分配给 nlohmann::json
- 引用 std::shared:ptr 以避免引用计数
- 为什么我不能在不进行任何转换的情况下将浮点数放入任何类型的 ptr 中?
- 在调用函数时,ptr** 和 ptr*& 之间是否有区别,或者首选C++?
- 另一种类型的智能ptr,比如具有弱refs的unique_ptr
- 尝试打印出 *ptr++ 的值,以了解它是如何工作的
- 如何控制共享 ptr 引用计数?
- dopen():不以 root 身份运行时"failed to map segment from shared object"
- C++中的指针否定 (!ptr == NULL)
- 从const ptr*转换为ptr*时出现问题
- 无法使用 libtool 将 -shared 参数传递给 g++
- boost::shared_ptr和std::shared-ptr的同居
- 我可以用std::shared_ptr而不是boost::shared-ptr构建boost库吗
- shared-ptr-C++shared_ptr与unique_ptr用于资源管理