【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
  • 避免在整型和指针类型之间重载。

原著在线阅读地址

相关推荐
2401_891482179 分钟前
C++代码复杂性分析
开发语言·c++·算法
mjhcsp17 分钟前
C++ 梯度下降法(Gradient Descent):数值优化的核心迭代算法
开发语言·c++·算法
yunyun3212324 分钟前
跨语言调用C++接口
开发语言·c++·算法
m0_5180194828 分钟前
C++中的装饰器模式变体
开发语言·c++·算法
xushichao198934 分钟前
高性能密码学库
开发语言·c++·算法
偷懒下载原神34 分钟前
【linux操作系统】信号
linux·运维·服务器·开发语言·c++·git·后端
m0_5180194837 分钟前
C++代码混淆与保护
开发语言·c++·算法
m0_5698814739 分钟前
C++中的智能指针详解
开发语言·c++·算法
2401_873544921 小时前
基于C++的游戏引擎开发
开发语言·c++·算法
add45a1 小时前
C++中的组合模式
开发语言·c++·算法