F_JustWei's Studio.

NULL与nullptr

字数统计: 637阅读时长: 2 min
2021/04/05 Share

NULL与nullptr

1、C程序中的NULL

在C语言中,NULL通常被定义为:

1
#define NULL ((void *)0)

所以说NULL实际上是一个空指针,如果在C语言中写入以下代码,编译是没有问题的,因为在C语言中把空指针赋给int和char指针的时候,发生了隐式类型转换,把void指针转换成了相应类型的指针。

1
2
int  *pi = NULL;
char *pc = NULL;

2、C++程序中的NULL

但是问题来了,以上代码如果使用C++编译器来编译则是会出错的,因为C++是强类型语言,void*是不能隐式转换成其他类型的指针的,所以实际上编译器提供的头文件做了相应的处理:

1
2
3
4
5
#ifdef __cplusplus
#define NULL 0
#else
#define NULL ((void *)0)
#endif

可见,在C++中,NULL实际上是0。因为C++中不能把void*类型的指针隐式转换成其他类型的指针,所以为了结果空指针的表示问题,C++引入了0来表示空指针,这样就有了上述代码中的NULL宏定义。

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
#include <iostream>
using namespace std;
void Func(void* t)
{
cout << "Func1" << endl;
}
void Func(int t)
{
cout << "Func2" << endl;
}
int main()
{
Func(NULL);
Func(nullptr);

return 0;
}

输出:

1
2
Func2
Func1

在这段代码中,我们对函数func进行可重载,参数分别是void*类型和int类型,但是运行结果却与我们使用NULL的初衷是相违背的,因为我们本来是想用NULL来代替空指针,但是在将NULL输入到函数中时,它却选择了int形参这个函数版本,所以是有问题的,这就是用NULL代替空指针在C++程序中的二义性。

3、C++程序中的nullptr

为解决NULL代指空指针存在的二义性问题,在C++11版本中特意引入了nullptr这一新的关键字来代指空指针,从上面的例子中我们可以看到,使用nullptr作为实参,确实选择了正确的以void*作为形参的函数版本。

4、总结

NULL在C++中就是0,这是因为在C++中void* 类型是不允许隐式转换成其他类型的。所以在C++程序中用0来代表空指针,在重载整形的情况下,会出现上述的问题。所以,C++11加入了nullptr,可以保证在任何情况下都代表空指针,而不会出现上述的情况。

参考链接

C++中NULL和nullptr的区别

CATALOG
  1. 1. NULL与nullptr
    1. 1.0.1. 1、C程序中的NULL
    2. 1.0.2. 2、C++程序中的NULL
    3. 1.0.3. 3、C++程序中的nullptr
    4. 1.0.4. 4、总结
    5. 1.0.5. 参考链接