在c++++中,智能指针的传递应根据所有权语义选择:std::shared_ptr需共享所有权时按值传递,仅访问时用const引用避免开销;std::unique_ptr转移所有权时按值传递并使用std::move,仅使用对象时传t&或t*以避免暴露智能指针类型,工厂函数应按值返回利用rvo优化,关键在于依据语义而非性能盲目选择传递方式,确保资源安全与接口清晰。

在C++中使用智能指针(如
std::shared_ptr
std::unique_ptr
std::shared_ptr
std::shared_ptr
void processObject(std::shared_ptr<MyClass> ptr) {
// 使用 ptr,可能延长对象生命周期
ptr->doSomething();
}理由:
shared_ptr
void inspectObject(const std::shared_ptr<MyClass>& ptr) {
if (ptr) {
ptr->inspect();
}
}适用场景:
⚠️ 注意:不要为了“节省拷贝”而滥用引用传递。如果函数可能异步使用指针(如存入队列),必须按值传递以确保生命周期安全。
std::unique_ptr
std::unique_ptr
void takeOwnership(std::unique_ptr<MyClass> ptr) {
ptr->run();
// 函数结束时自动释放资源
}调用方式:
auto obj = std::make_unique<MyClass>(); takeOwnership(std::move(obj));
理由:
如果函数只是使用对象,不获取所有权:
void useObject(const MyClass& obj) {
obj.doWork();
}
// 或者接受 const unique_ptr&(较少用)
void useObjectPtr(const std::unique_ptr<MyClass>& ptr) {
if (ptr) ptr->doWork();
}更推荐直接传引用或指针,避免暴露智能指针类型:
void useObject(MyClass* ptr) {
if (ptr) ptr->doWork();
}| 场景 | 推荐方式 | 说明 |
|---|---|---|
| @@######@@:函数需共享所有权 | 按值传递 | 安全延长生命周期 |
| @@######@@:仅临时使用,不延长生命周期 | @@######@@ | 避免引用计数开销 |
| @@######@@:转移所有权 | 按值传递 + @@######@@ | 唯一所有权转移方式 |
| @@######@@:仅使用对象 | 传 @@######@@ 或 @@######@@ | 不暴露智能指针,更通用 |
| 工厂函数返回智能指针 | 按值返回 | 编译器优化(RVO/移动)高效 |
shared_ptr
shared_ptr
const shared_ptr<T>&
基本上就这些。关键在于:
按值传递智能指针意味着共享或转移所有权,按引用/指针传递仅表示临时使用。
根据语义选择方式,而不是单纯追求“性能”。
unique_ptr
std::move
unique_ptr
T&
T*
shared_ptr
unique_ptr
std::move
以上就是如何传递智能指针参数 按值按引用传递最佳实践的详细内容,更多请关注php中文网其它相关文章!
每个人都需要一台速度更快、更稳定的 PC。随着时间的推移,垃圾文件、旧注册表数据和不必要的后台进程会占用资源并降低性能。幸运的是,许多工具可以让 Windows 保持平稳运行。
Copyright 2014-2025 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号