'Subtraction of two nullptr values guaranteed to be zero?
Is it guaranteed by the C++ standard that if I have two pointers of the same type whose value is equal to nullptr, that the difference between those pointers is equal to 0?
In a pseudo-mathematical notation, does the following predicate hold true?
ForAll x ForAll y (x == nullptr)^(y == nullptr) -> (x - y == 0)
The simplest code example I can think of being:
int* x = nullptr;
int* y = nullptr;
assert(x - y == 0);
I suppose this boils down to: is it possible to have a valid implementation of the C++ standard for which there are multiple bit representations of nullptr that only compare as being equal because the equality operator does some magic?
Solution 1:[1]
Yes, that is valid. It would be undefined in C, but C++ has added a special exception to the - operator to define the behaviour.
5.7 Additive operators [expr.add]
7 If the value
0is added to or subtracted from a pointer value, the result compares equal to the original pointer value. If two pointers point to the same object or both point one past the end of the same array or both are null, and the two pointers are subtracted, the result compares equal to the value0converted to the typestd::ptrdiff_t.
Sources
This article follows the attribution requirements of Stack Overflow and is licensed under CC BY-SA 3.0.
Source: Stack Overflow
| Solution | Source |
|---|---|
| Solution 1 | Community |
