使用智能指针作函数参数应根据所有权需求选择:仅访问时用const shared_ptr&避免开销;需共享所有权时按值传递shared_ptr;独占所有权用unique_ptr并配合std::move;若无需管理生命周期,则优先使用T*或T&以提升效率。

在C++中,智能指针是管理动态内存的有效工具,能自动释放资源,避免内存泄漏。当涉及到函数参数传递时,合理使用智能指针不仅能提升代码安全性,还能明确对象的所有权语义。以下是关于智能指针在函数参数中应用的实用建议。
使用const引用传递shared_ptr以避免不必要的增加引用计数
当你只需要访问对象,不涉及所有权转移时,推荐使用const std::shared_ptr
- 避免了构造新shared_ptr带来的原子操作开销(引用计数加1)
- 确保函数不会修改指针本身
- 适用于大多数只读场景
示例:
void printValue(const std::shared_ptrif (ptr) ptr->print();
}
通过值传递shared_ptr表示共享所有权
如果函数需要长期持有对象,比如存入容器或跨线程传递,应以值方式接收std::shared_ptr
立即学习“C++免费学习笔记(深入)”;
- 明确表示函数要共享对象生命周期
- 内部会正确增加引用计数
- 适合用于注册回调、缓存等场景
示例:
void registerObject(std::shared_ptrwidgetList.push_back(widget);
}
使用unique_ptr传递独占所有权
当函数应完全接管对象生命周期时,使用std::unique_ptr
- 清晰表达所有权转移
- 调用方必须使用std::move
- 防止资源被意外复制
示例:
void processTask(std::unique_ptrtask->run();
}
auto t = std::make_unique
processTask(std::move(t)); // 显式转移
优先使用原始指针或引用传递,若无需管理生命周期
如果函数只是临时使用对象,且调用者保证对象有效,直接使用T*或T&更高效。
- 避免引入智能指针的开销
- 适用于短生命周期、栈对象或已知存活期的场景
- 接口更轻量
示例:
void updateData(MyStruct* data) {if (data) data->flag = true;
}
基本上就这些。关键在于根据是否需要管理生命周期来选择参数类型:共享用shared_ptr(注意传递方式),独占用unique_ptr,仅访问则用原始指针或引用。这样既能保证安全,又兼顾性能。










