走进C++11(十一) nullptr/nullptr_t

本文详细介绍了C++11中引入的nullptr关键字,解释了它与NULL的区别,以及为何需要引入nullptr。通过示例展示了nullptr如何避免类型歧义,并强调了nullptr的类型特性。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

 

解释

 

关键词 nullptr 代表指针字面量。它是 std::nullptr_t 类型的纯右值。存在从 nullptr 到任何指针类型及任何成员指针类型的隐式转换。同样的转换对于任何空指针常量也存在,空指针常量包括 std::nullptr_t 的值,以及宏 NULL。

 

引入原因

 

为什么引入nullptr呢, 不是有NULL这个关键字么?

 

的却,但是我想问你NULL是什么类型的?

 

C++98中NULL是个宏定义,明确规定NULL是个整型0值:

 

/* Define NULL pointer value */#ifndef NULL    #ifdef __cplusplus        #define NULL    0    #else  /* __cplusplus */        #define NULL    ((void *)0)    #endif  /* __cplusplus */#endif  /* NULL */

 

C中NULL规定为void*指针:

 

#define  NULL  ((void*)0)

 

可以看出,C和C++中NULL的规定是不同的,原因在于C++的重载机制。

 

void foo(int) {}void foo(int*) {}
foo(0);  // 调用foo(int)而不是foo(int*)foo(NULL);  // 如果NULL是0,则调用foo(int); 如果NULL是0L,则编译错误

 

C++98规定NULL是一个整型0值,根据不同的编译器实现,可能是0或0L。更尴尬的是,可以拿NULL当合法的整型(int或者long)来使用,所以C++11引入了nullptr表示指针的0值,虽然它不是指针类型,但是它能够转换成任何指针,而且它不能转换成int或者其他类型:

 

void foo(char *);void foo(int);#include <iostream>#include <typeinfo>int main(){  std::cout << "" << typeid(NULL).name() << std::endl;}foo(0); // 调用 foo(int)// foo(NULL); // 该行不能通过编译foo(nullptr); // 调用 foo(char*)

 

std::nullptr_t

 

nullptr也有其自身的类型,它的类型为std::nullptr_t。std::nullptr_t本身不是指针类型,但是它可以转换为任何指针类型,这也就是nullptr可以看做任何指针类型的原因。它的定义如下:

 

typedef decltype(nullptr) nullptr_t;

 

上面是一个很有趣的类型定义。通常情况是先有类型,然后才有该类型的变量。而上面的定义则是,先有一个某类型的字面值,再由这个字面值定义它的类型。妙哉!

 

关注公众号获取更多信息:

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值