使用 * 的智能指针行为
Smart Pointer behavior using *
我有以下代码片段:
QList<const GLMeshPtr*> meshList;
m_itemsList->getSelectedMeshes(meshList);
for (auto m : meshList)
{
if (GLBodyPtr c = (*m)->getStandard()) {
c->executeMeshFix();
}
}
GLMeshPtr
设置如下typedef
:
typedef std::shared_ptr<GLMesh> GLMeshPtr;
m_itemsList->getSelectedMeshes
的定义是:
void QMeshList::getSelectedMeshes(QList<const GLMeshPtr*>& list)
{
for (auto& m : m_meshList) {
if (m->isSelected()) {
list.push_back(m->getGLMesh());
}
}
}
getGLMesh
的定义是:
const GLMeshPtr* getGLMesh() const { return &m_glmesh; } // where m_glmesh is a GLMeshPtr.
我的问题很简单,但是,我找不到任何参考资料。*
关键字是否一定会在堆栈中创建值的副本,或者它是否使用值"就地"?
我更具体地谈论这一行:
if (GLBodyPtr c = (*m)->getStandard()) {
我是否正在创建不必要的 GLBodyptr 副本?我不希望这里的任何人分享指针。
不,* 运算符返回一个引用,即GLBodyPtr const&
.之所以const
,是因为指针被声明为指向 const 对象。请参阅 cppreference.com 上std::shared_ptr::operator*
的定义。
引用基本上就像指针一样,一旦初始化就无法更改,因此它不是shared_ptr
对象的副本。
相关文章:
- 1d 智能指针不适用于语法 (*)++
- 优先顺序:智能指针和类析构函数
- 对于C++中使用智能指针的指针算术限制,有没有一种变通方法
- 智能指针作为无序映射键,并通过引用进行比较
- 智能指针概念所有权和寿命
- 正在理解智能指针,但出现错误:未分配正在释放的指针
- 尝试使用智能指针时引发异常
- 我可以制作指向智能指针的智能指针吗?
- 通过智能指针和转换对基本模板参数进行模板推导
- OpenCV 我应该使用智能指针来防止内存泄漏吗?
- 从堆栈分配的原始指针构造智能指针
- 初始化指向类实例的智能指针并访问其方法
- 如何使用 std::make_shared 创建基类类型的智能指针?
- 给定一个指向堆分配内存的指针,智能指针实现如何为其找到合适的释放函数?
- 编译器不会使用 -std=c++11 编译智能指针
- 具有智能指针的多态性
- C++:矢量分配器行为、内存分配和智能指针
- 通过简单的包装指针C++智能指针性能和差异
- 矢量中的自动指针(智能)
- Std::vector的对象/指针/智能指针传递对象(总线错误:10)