【Effective Modern C++】第三章 转向现代C++:8. 优先选用nullptr,而非0或NULL

当C++在只能使用指针的语境中发现了0会把勉强解释为空指针,但是C++的基本观点还是0和NULL的类型是int,而非指针

在C++98中,这样的观点可能在指针类型和整型之间进行重载时可能会发生意外:

c++ 复制代码
void f(int);        // 整型版本
void f(bool);       // 布尔版本
void f(void*);      // 指针版本

f(0);               // 调用 f(int),而不是 f(void*)!
f(NULL);            // 可能通不过编译,但一般会调用 f(int)。从来不会调用 f(void*)
f(nullptr);         // 正确调用 f(void*)

nullptr的优点

它不具备整型类型。实际类型是std::nullptr_t,并且可以隐式转换到所有的裸指针类型。

提升代码的可读性:

c++ 复制代码
// 使用 0/NULL 的歧义
auto result = findRecord();
if (result == 0) {  // result 是指针还是整数?不明确
    // ...
}

// 使用 nullptr 的明确性
auto result = findRecord();
if (result == nullptr) {  // 明确是指针比较
    // ...
}

在使用模板时具有显著优势(模板类型推导会严格将 0/NULL 解析为整型,而非空指针语义):

c++ 复制代码
int f1(std::shared_ptr<Widget> spw); 
double f2(std::unique_ptr<Widget> upw); 
bool f3(Widget* pw); 

// 模板函数 
template<typename FuncType, typename PtrType> 
decltype(auto) lockAndCall(FuncType func, PtrType ptr) { 
	// ... 加锁等操作 
	return func(ptr); 
} 

// 调用结果 
auto r1 = lockAndCall(f1, 0); // 编译错误:0被推导为int,无法转为shared_ptr 
auto r2 = lockAndCall(f2, NULL); // 编译错误:NULL被推导为整型,无法转为unique_ptr 
auto r3 = lockAndCall(f3, nullptr);// 正确:nullptr_t可隐式转为Widget*

总结

  • 相对于0或NULL,优先选用nullptr
  • 避免在整型和指针类型之间重载。

原著在线阅读地址

相关推荐
一只小小的芙厨2 小时前
AT_tkppc3_d 巨大チェスボード 题解
c++·题解
我在人间贩卖青春2 小时前
C++之继承与派生类的关系
c++·向上造型·向下造型
Trouvaille ~2 小时前
【Linux】应用层协议设计实战(二):Jsoncpp序列化与完整实现
linux·运维·服务器·网络·c++·json·应用层
EmbedLinX2 小时前
嵌入式之协议解析
linux·网络·c++·笔记·学习
wangjialelele3 小时前
Linux中的进程管理
java·linux·服务器·c语言·c++·个人开发
历程里程碑3 小时前
普通数组----轮转数组
java·数据结构·c++·算法·spring·leetcode·eclipse
李日灐3 小时前
C++进阶必备:红黑树从 0 到 1: 手撕底层,带你搞懂平衡二叉树的平衡逻辑与黑高检验
开发语言·数据结构·c++·后端·面试·红黑树·自平衡二叉搜索树
汉克老师3 小时前
GESP2025年6月认证C++二级( 第一部分选择题(1-8))
c++·循环结构·表达式·分支结构·gesp二级·gesp2级
rainbow68893 小时前
C++高性能框架Drogon:后端开发新标杆
c++
Q741_1473 小时前
C++ 优先级队列 大小堆 模拟 力扣 703. 数据流中的第 K 大元素 每日一题
c++·算法·leetcode·优先级队列·