“(T *)0 - (T *)0”是否明确定义为 0
Is `(T *)0 - (T *)0` well-defined to be 0?
请考虑以下代码:
#include <iostream>
int main()
{
int *a = 0, *b = 0;
std::cout << (a - b);
}
在 ideone 上,这段代码按预期打印 0,但我不确定它是否是明确定义的行为。
我想知道(T*)0 - (T*)0
是否定义明确?保证等于0
吗?
C 和 C++ 中相同吗?如果不是,有什么区别?
(当然,T
既不void
也不std::nullptr_t
,因为指针算术对它们不起作用。
在C++中,请参阅 [expr.add]/7:
如果两个指针 [...] 都是空的,并且两个指针是 减去,结果等于
0
转换为的值 类型std::ptrdiff_t
.
(这也适用于P0137,它缩短了这一段。
在 C11 中,该行为显然未定义,如 6.5.6/9 所示:
当减去两个指针时,两个指针都应指向 相同的数组对象,或超过数组对象的最后一个元素; 结果是两个数组的下标的差异 元素。
相关文章:
- 此递归模板类型定义是否有效C++?
- 虚拟成员函数的定义是否强制在同一转换单元中动态初始化静态数据成员?
- 越界成员函数定义是否需要一个完全限定的类名,直到全局范围
- C++标准是否定义了结构中成员函数的函数内定义是否必须具有静态链接?
- 带有"struct structname<..>"的模板定义是否正确?
- NTRUEncrypt:使用开源标准算法中的描述无法正确找到两个多项式的GCD,无法定义是否存在多边形的逆
- 定义重载C++函数模板的原型时,使用其名称引用以前的定义是否合法?
- 命名空间的定义是否可以跨越多个翻译单元
- 头文件中的类声明和定义是否在每个包含上编译
- 这个无括号的C预处理器定义是否安全
- char的实现定义是否会影响std::string
- 对内联函数有不同的定义是否是一种未定义的行为
- 同一字符串的多个#定义是否使用相同的常量字符串
- 根据编译时常量,使用相同的标识符 #define 或类型定义是否被认为是可接受的做法?
- 显式模板实例化定义是否也抑制隐式实例化
- 构造函数定义是否可以以 "class" 关键字为前缀?
- 类中的函数定义是否占用类大小的一部分?
- 名称空间作用域构造函数定义是否需要类限定的标识符
- i=i++;未定义.是否i=foo(i++)也未定义
- "volatile"的定义是否如此不稳定,还是 GCC 存在一些标准合规性问题?