答案:unique_ptr和shared_ptr可直接用于条件判断或与nullptr比较,而weak_ptr需通过lock()转换为shared_ptr后判空。

在C++中,检查智能指针是否为空是一个常见操作。智能指针本质上是类模板对象,它们重载了布尔转换操作符,因此可以直接在条件判断中使用。以下是针对不同类型的智能指针(std::unique_ptr、std::shared_ptr、std::weak_ptr)的判空方法。
1. std::unique_ptr 判空
std::unique_ptr 表示独占所有权的智能指针。判断其是否为空,可以直接用于条件语句,或调用 operator bool()。
示例:
std::unique_ptrptr; if (ptr) { /* 指向有效对象 */ }if (!ptr) { /* 为空,未指向任何对象 */ }- 也可以显式比较:
if (ptr.get() == nullptr)
推荐直接使用 if (ptr),更简洁且符合习惯。
立即学习“C++免费学习笔记(深入)”;
2. std::shared_ptr 判空
std::shared_ptr 使用引用计数管理资源。即使多个 shared_ptr 共享同一对象,只要有一个非空,资源就不会释放。判空方式与 unique_ptr 类似。
示例:
std::shared_ptrsptr = nullptr; if (sptr) { /* 非空 */ }if (sptr != nullptr) { /* 等效写法 */ }
注意:shared_ptr 的空状态与其引用计数无关,即使引用计数为0,只要指针本身为空,if(sptr) 就为 false。
3. std::weak_ptr 判空
std::weak_ptr 不增加引用计数,用于避免循环引用。它不能直接解引用,必须先通过 lock() 转为 shared_ptr。由于 weak_ptr 可能指向已被释放的对象,因此不能像其他指针一样直接用于布尔判断。
正确判空方式:
std::weak_ptrwptr = sptr; if (auto locked = wptr.lock()) { /* 转为 shared_ptr 成功,原对象仍存在 */ }else { /* 原对象已释放,weak_ptr 为空或失效 */ }
不能写成 if (wptr),因为 weak_ptr 没有定义隐式布尔转换。
总结
不同智能指针的判空方法如下:
- unique_ptr 和 shared_ptr:直接用于 if 条件,或与 nullptr 比较。
- weak_ptr:必须使用 lock() 获取 shared_ptr 后判断。
基本上就这些,不复杂但容易忽略 weak_ptr 的特殊性。











