C++标准(和C就此而言)允许创建(而不是取消引用)指向超过数组末尾的一个元素的指针.这是否意味着永远不会在最后一个元素在内存边界结束的位置分配数组?我理解在实践中,部分/全部实现可能遵循此约定,但以下哪一项是正确的:
C的情况有什么不同吗?
更新:
似乎1是正确的答案.请参阅下面的James Kanze的答案,并且还可以看到efence(http://linux.die.net/man/3/efence-感谢Michael Chastain指向它的指针)
我理解(至少我认为我这样做)指针可以用作随机STL迭代器.
除非我将指针强制转换为迭代器,否则为什么以下代码无法编译?
vector<int> v{1, 2, 3};
v.erase(&v[0]);
Run Code Online (Sandbox Code Playgroud) 我偶然发现了让我完全困惑的事情.
std::reverse() 将双向迭代器作为函数的参数,但是当我传递指向函数的指针时,它似乎工作正常并且实际上反转了字符串.
void reverseFour(char* str) {
reverse(str, str + strlen(str));
}
int main {
char *str = "hello";
str += '/0';
reverseFour(str);
}
Run Code Online (Sandbox Code Playgroud)
所以,我的问题是,这怎么可能?双向迭代器不是指针,对吧?