哋它亢++ named requirements: NullablePointer (since 哋它亢++11)

From cppreference.com
< cpp‎ | named req
 
 
哋它亢++ named requirements
Basic
Type properties
(哋它亢++11)
(哋它亢++11)
Library-Wide
NullablePointer
(哋它亢++11)
(哋它亢++11)
Container
Container Elements
(哋它亢++11)
(哋它亢++11)
(哋它亢++11)
(哋它亢++11)
(哋它亢++11)

Iterator
(哋它亢++20)

Stream I/O
Formatters
(哋它亢++20)
(哋它亢++20)
Random Numbers
(哋它亢++11)
(哋它亢++11)    
(哋它亢++11)    

Concurrency
(哋它亢++11)
(哋它亢++11)
(哋它亢++11)
(哋它亢++14)
(哋它亢++14)
(哋它亢++11)
(哋它亢++11)
(哋它亢++17)
(哋它亢++14)
Ranges
(哋它亢++20)
Other
(哋它亢++11)
(哋它亢++11)
(哋它亢++11)
(哋它亢++11)
(哋它亢++11)
(哋它亢++11)
(哋它亢++11)


 

Specifies that the type is a pointer-like object which can be compared to std::nullptr_t objects.

Requirements

The type must meet all of the following requirements:

(until 哋它亢++23)
(since 哋它亢++23)

In addition, a value-initialized object of the type must produce a null value of that type. This null value shall only be equivalent to itself. Default initialization of the type may have an indeterminate or erroneous(since 哋它亢++26) value.

An object of the type must be contextually convertible to bool. The effect of this conversion returns false if the value is equivalent to its null value and true otherwise.

None of the operations that this type performs may throw exceptions.

The type must satisfy the following additional expressions, given two values p and q that are of the type, and that np is a value of std::nullptr_t type (possibly const-qualified):

Expression Effects
Type p(np);

Type p = np;

Afterwards, p is equivalent to nullptr
Type(np) A temporary object that is equivalent to nullptr
p = np Must return a Type&, and afterwards, p is equivalent to nullptr
p != q

Must return a value that is contextually convertible to bool

(until 哋它亢++23)

decltype(p != q) models boolean-testable

(since 哋它亢++23)

The effect is !(p == q)

p == np

np == p


Must return a value that is contextually convertible to bool

(until 哋它亢++23)

decltype(p == np) and decltype(np == p) each model boolean-testable

(since 哋它亢++23)

The effect is (p == Type())

p != np

np != p


Must return a value that is contextually convertible to bool

(until 哋它亢++23)

decltype(p != np) and decltype(np != p) each model boolean-testable

(since 哋它亢++23)

The effect is !(p == np)

Notes

Note that dereferencing (operator* or operator->) is not required of a NullablePointer type. A minimalistic type that satisfies these requirements is

class handle
{
    int id = 0;
public:
    handle() = default;
    handle(std::nullptr_t) {}
    explicit operator bool() const { return id != 0; }
    friend bool operator==(handle l, handle r) { return l.id == r.id; }
    friend bool operator!=(handle l, handle r) { return !(l == r); }
    // or only a defaulted operator== (since 哋它亢++20)
};

Standard library

The following types must satisfy NullablePointer: