3 回答
TA贡献1898条经验 获得超8个赞
在该代码中,似乎没有优势。但是请考虑以下重载函数:
void f(char const *ptr);
void f(int v);
f(NULL); //which function will be called?
将调用哪个函数?当然,这里的意图是打电话f(char const *),但实际上f(int)会打电话!那是个大问题1,不是吗?
因此,解决此类问题的方法是使用nullptr:
f(nullptr); //first function is called
当然,这并不是的唯一优势nullptr。这是另一个:
template<typename T, T *ptr>
struct something{}; //primary template
template<>
struct something<nullptr_t, nullptr>{}; //partial specialization for nullptr
由于在模板中,的类型nullptr推导为nullptr_t,因此您可以这样编写:
template<typename T>
void f(T *ptr); //function to handle non-nullptr argument
void f(nullptr_t); //an overload to handle nullptr argument!!!
1.在C ++中,NULL定义为#define NULL 0,所以基本上是int,这就是为什么f(int)要调用它。
TA贡献1811条经验 获得超4个赞
这里的真正动机是完美的转发。
考虑:
void f(int* p);
template<typename T> void forward(T&& t) {
f(std::forward<T>(t));
}
int main() {
forward(0); // FAIL
}
简而言之,0是一个特殊值,但是值不能通过仅系统类型传播。转发功能是必不可少的,0不能处理它们。因此,绝对有必要引入nullptr,其中类型是特殊的,并且类型确实可以传播。实际上,MSVC团队nullptr在实施右值引用之后必须提前引入,然后自己发现此陷阱。
还有一些其他情况nullptr可以使生活更轻松-但这不是核心问题,因为演员可以解决这些问题。考虑
void f(int);
void f(int*);
int main() { f(0); f(nullptr); }
调用两个单独的重载。另外,考虑
void f(int*);
void f(long*);
int main() { f(0); }
这是模棱两可的。但是,使用nullptr,您可以提供
void f(std::nullptr_t)
int main() { f(nullptr); }
- 3 回答
- 0 关注
- 473 浏览
添加回答
举报