四十不环 发表于 2018-8-3 22:28:18

*(*(*array + 1) + 2), ***array, *(**array + 1)的演算过程?

#include <stdio.h>

int main()
{
      char array = {
                {
                        {'x', 'x', 'x', 'x', 'x'},
                        {'x', 'x', 'o', 'x', 'x'},
                        {'x', 'x', 'x', 'x', 'x'}
                },
                {
                        {'x', 'x', 'x', 'x', 'x'},
                        {'x', 'x', 'o', 'x', 'x'},
                        {'x', 'x', 'x', 'x', 'x'}
                }
      };

      printf("%c%c%c%c\n", *(*(*array + 1) + 2), *(*(*(array + 1) + 1) + 2), ***array, *(**array + 1));

      return 0;
}
这个程序具体的演算过程是什么?求大神指点。

claws0n 发表于 2018-8-3 23:00:42

本帖最后由 claws0n 于 2018-8-3 23:03 编辑

{{
{'1', '2', '3', '4', '5'},
{'6', '7', '8', '9', 'A'},
{'B', 'C', 'D', 'E', 'F'}},
{
{'G', 'H', 'I', 'J', 'K'},
{'L', 'M', 'N', 'O', 'P'},
{'Q', 'R', 'S', 'T', 'U'}}}
不要用 xxoo....
如果只有 array,那就是首地址。你的 array 有三个维度,解引用有三层。

*(*(*array + 1) + 2)
第一层已经解引用了,指向首元素,往下一步,往右两步 ('8')

*(*(*(array + 1) + 1) + 2)
整个 array 的跨度是15。第一次垮了15步,到了第二页的首地址。同理,往下一步,往右两步。('N')

***array
什么都没动,直接解引用,就是整个数组的第一个元素。('1')

*(**array + 1)
先解了两次,没有调变,所以是第一页,第一行,往右一步。('2')
页: [1]
查看完整版本: *(*(*array + 1) + 2), ***array, *(**array + 1)的演算过程?