C反转索引器和数组名称

前端之家收集整理的这篇文章主要介绍了C反转索引器和数组名称前端之家小编觉得挺不错的,现在分享给大家,也给大家做个参考。
参见英文答案 > With arrays,why is it the case that a[5] == 5[a]?15个
我在网路上遇到过,想知道有人能够解释一下,至少给我一个可能的名字,以至于我至少知道我在搜索什么.
int main()
{
   int myarray[4] = {0,100,200,300};
   2[myarray] = -999;  //why does this work? what is this called?

   for ( int i = 0; i < 4; i++) 
      cout << myarray[i] << endl;
}

输出为0,-999,300

我跑了我知道它是有效的,但为什么?这个叫什么?

解决方法

这是因为arr [n] == *(arr n).

但是,由于加法是可交换的,*(arr n)== *(n arr).因此,*(n arr)== n [arr] == *(arr n)== arr [n].

值得一提的是,*(arr n)仍然有点误导.在汇编中它实际上意味着*(arr(n * s))其中s是sizeof arr [0],但这是在封面下,所以你不需要担心.

猜你在找的C&C++相关文章