nullptr替代NULL因其类型安全、避免重载歧义和模板推导错误,提升代码可读性与安全性。

在C++11中,nullptr被引入用来替代传统的NULL宏,以更安全、更清晰地表示空指针。使用nullptr可以避免一些由于NULL定义带来的类型推断问题和函数重载歧义。
为什么用nullptr替代NULL?
NULL通常被定义为0或(void*)0(在C++中一般是0),这会导致一些潜在问题:
- 当NULL是整数0时,在函数重载中可能匹配到int参数而不是指针参数。
- 模板推导时,传入NULL可能导致类型被推导为int而非指针类型。
- 代码可读性差,0既可以是整数也可以是空指针,语义不明确。
而nullptr是一个字面量,其类型为std::nullptr_t,专门用于表示空指针,能正确隐式转换到任意指针类型。
如何使用nullptr
使用nullptr非常简单,直接替换原来使用NULL或0的地方即可:
立即学习“C++免费学习笔记(深入)”;
// 旧方式:使用NULL或0 int* p1 = NULL; int* p2 = 0;// C++11新方式:使用nullptr int p3 = nullptr; char str = nullptr; void* ptr = nullptr;
在条件判断中也完全兼容:
if (ptr == nullptr) {
// 指针为空
}
nullptr解决函数重载歧义
这是nullptr最大的优势之一。看下面的例子:
void func(int x) {
std::cout << "Called func(int): " << x << std::endl;
}
void func(char p) {
std::cout << "Called func(char): " << (p ? p : "null") << std::endl;
}
func(NULL); // 调用func(int),因为NULL是0,有歧义!
func(nullptr); // 明确调用func(char*)
使用nullptr后,编译器能准确选择指针版本的重载函数,避免意外行为。
模板编程中的优势
在模板中传递空指针时,nullptr也能保证类型正确:
templatevoid process(T* ptr) { if (ptr) { /* 处理指针 */ } } // 正确推导为指针类型 process(nullptr); // T被正确推导为目标指针的类型
如果传入NULL(即0),T可能被错误推导为int。
基本上就这些。从现在起,建议所有新代码都用nullptr代替NULL或0来表示空指针,提升代码安全性与可读性。










