nullptr, the pointer literal
cppreference.com
Syntax
nullptr
|
(since C++11) | ||||||||
Explanation
The keyword nullptr denotes the pointer literal. It is a prvalue of type std::nullptr_t. There exist implicit conversions from nullptr to null pointer value of any pointer type and any pointer to member type. Similar conversions exist for any null pointer constant, which includes values of type std::nullptr_t as well as the macro NULL.
Example
Demonstrates that nullptr retains the meaning of null pointer constant even if it is no longer a literal.
코드 실행
#include <cstddef>
#include <iostream>
template<class T>
constexpr T clone(const T& t)
{
return t;
}
void g(int*)
{
std::cout << "Function g called\n";
}
int main()
{
g(nullptr); // Fine
g(NULL); // Fine
g(0); // Fine
g(clone(nullptr)); // Fine
// g(clone(NULL)); // ERROR: non-literal zero cannot be a null pointer constant
// g(clone(0)); // ERROR: non-literal zero cannot be a null pointer constant
}
Output:
Function g called
Function g called
Function g called
Function g called
Keywords
References
- C++20 standard (ISO/IEC 14882:2020):
- 7.3.12 Pointer conversions [conv.ptr]
- C++17 standard (ISO/IEC 14882:2017):
- 7.11 Pointer conversions [conv.ptr]
- C++14 standard (ISO/IEC 14882:2014):
- 4.10 Pointer conversions [conv.ptr]
- C++11 standard (ISO/IEC 14882:2011):
- 4.10 Pointer conversions [conv.ptr]
See also
| 구현에서 정의한 널 포인터 상수 (macro constant) | |
(C++11) |
널 포인터 리터럴인 nullptr 의 형 (typedef) |