我分配了一个包含 3 个元素的 int 数组,并想到了下面的代码:
int a[3];
for(int i = -2; i < 3; ++i){
a[i] = i;
cout<<a[i]<<" ";
}
这是它的输出:
-2 -1 0 1 2
看起来数组 a 有 5 个分配空间,而 a 位于这些空间的中间。有任何想法吗?
原文由 user8600953 发布,翻译遵循 CC BY-SA 4.0 许可协议
我分配了一个包含 3 个元素的 int 数组,并想到了下面的代码:
int a[3];
for(int i = -2; i < 3; ++i){
a[i] = i;
cout<<a[i]<<" ";
}
这是它的输出:
-2 -1 0 1 2
看起来数组 a 有 5 个分配空间,而 a 位于这些空间的中间。有任何想法吗?
原文由 user8600953 发布,翻译遵循 CC BY-SA 4.0 许可协议
3 回答2k 阅读✓ 已解决
2 回答3.9k 阅读✓ 已解决
2 回答3.2k 阅读✓ 已解决
1 回答3.2k 阅读✓ 已解决
1 回答2.7k 阅读✓ 已解决
3 回答3.4k 阅读
1 回答1.6k 阅读✓ 已解决
要解释负索引是如何工作的,您首先必须了解(或记住)对于任何数组或指针
a
和索引i
,表达式a[i]
到*(a + i)
。这意味着您可以有一个指向数组中间元素的指针,并将其与正或负索引一起使用,这是简单的算术。
例子:
从图形上看,它可以看起来像
现在,当在数组中使用负索引时,如问题中的
a
示例,它将是这样的:也就是说,这里的负索引将 _超出数组的范围_,并会导致 _未定义的行为_。