C++标准(和C就此而言)允许创建(而不是取消引用)指向超过数组末尾的一个元素的指针.这是否意味着永远不会在最后一个元素在内存边界结束的位置分配数组?我理解在实践中,部分/全部实现可能遵循此约定,但以下哪一项是正确的:
C的情况有什么不同吗?
更新:
似乎1是正确的答案.请参阅下面的James Kanze的答案,并且还可以看到efence(http://linux.die.net/man/3/efence-感谢Michael Chastain指向它的指针)
更新:由用户ecatmur标记,它是In C99的副本,f()+ g()未定义或仅仅未指定?(虽然问题询问C99,但C++的答案没有变化).答案是:未指定(两种情况).
考虑以下C++ 14代码片段:
int i = 0;
int x() { i++; return i;}
int y() { i++; return i;}
bool z = (x() > y()); // unspecified or undefined ?
Run Code Online (Sandbox Code Playgroud)
z 仅仅是未指定的值,还是这种未定义的行为?
根据我的理解(请纠正,如果我错了),这种类型的表达式:i++ > i++将是未定义的行为,因为我们在一对序列点之间两次改变相同的变量,但是上面的情况如何(突变发生在单独的功能) ?
那一个怎么样:
bool z = (x() > i++); // undefined or unspecified now ?
Run Code Online (Sandbox Code Playgroud)