当前位置:  开发笔记 > 编程语言 > 正文

C++反转索引器和数组名称

如何解决《C++反转索引器和数组名称》经验,为你挑选了1个好方法。

我在网上看到了这个,并想知道是否有人能够解释这个或者至少给我一个可能的名称,这样我至少可以知道我在谷歌上搜索.

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,100,-999,300

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



1> erip..:

这种情况的原因是因为arr[n]== *(arr + n).

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

值得一提的*(arr + n)是,这仍然有点误导.在装配实际上就意味着*(arr + (n * s))哪里ssizeof arr[0],但是这是在幕后,所以你不必担心.

推荐阅读
地之南_816
这个屌丝很懒,什么也没留下!
DevBox开发工具箱 | 专业的在线开发工具网站    京公网安备 11010802040832号  |  京ICP备19059560号-6
Copyright © 1998 - 2020 DevBox.CN. All Rights Reserved devBox.cn 开发工具箱 版权所有