Item8 Prefer nullptr to 0 and NULL

   0int类型,并不是指针类型,但是当0赋值给一个指针类型的时候,0将会被解释成空指针,在C++98中关键字NULL其本质就是一个long int类型的数值0,在实际使用过程中这带来了很多模棱两可的问题。

void f(int);
void f(bool);
void f(void*);

   对于上面三个重载来说,如果调用f(0),那么会匹配第一个,如果调用f(NULL),这会导致重载决策失败,因为long int可以隐式转换为intboolvoid*,所以在函数重载决议的时候会模棱两可。如果有void f(long int)这样的重载的话那么f(NULL)是可以匹配的,在C++11中这一问题得到了解决,但是为了兼容之前的代码,NULL关键字还是保留原来的含义,引入了nullptr不再是整型了,但老实说它也不是空指针类型,而是std::nullptr_t类型,更奇怪的是std::nullptr_t的类型又是nullptr类型,这是一个循环类型定义,而std::nullptr_t类型可以隐式转换为任意类型的指针。

   在上面我提到了0可以隐式转换为指针类型,0本身是int类型,那么是不是int类型都可以转换为指针类型呢?

void test(void*);
test(0);
int data = 0;
test(data);

   很遗憾test(data)无法编译通过,因为无法从int类型转换为void*类型,了解了上面这个事实,那么下面这个例子你应该很容易就理解了。

template<typename FuncType,
         typename PtrType>
decltype(auto) Call(FuncType func,PtrType ptr) {
    return func(ptr);
}

Call(test,0);

   上面的调用会失败,因为0经过模板类型推导后变成了int类型的ptr,而int类型是无法转换为指针类型的。如果在这里把0换成nullptr就可以调用成功了。

©️2020 CSDN 皮肤主题: 编程工作室 设计师: CSDN官方博客 返回首页
实付0元
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值