鱼C论坛

 找回密码
 立即注册
查看: 1563|回复: 1

[已解决]*(*(*array + 1) + 2), ***array, *(**array + 1)的演算过程?

[复制链接]
发表于 2018-8-3 22:28:18 | 显示全部楼层 |阅读模式

马上注册,结交更多好友,享用更多功能^_^

您需要 登录 才可以下载或查看,没有账号?立即注册

x
#include <stdio.h>

int main()
{
        char array[2][3][5] = {
                {
                        {'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;
}
这个程序具体的演算过程是什么?求大神指点。
最佳答案
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 [2][3][5] 的跨度是15。第一次垮了15步,到了第二页的首地址。同理,往下一步,往右两步。('N')

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

*(**array + 1)
先解了两次,没有调变,所以是第一页,第一行,往右一步。('2')
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复

使用道具 举报

发表于 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 [2][3][5] 的跨度是15。第一次垮了15步,到了第二页的首地址。同理,往下一步,往右两步。('N')

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

*(**array + 1)
先解了两次,没有调变,所以是第一页,第一行,往右一步。('2')
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复 支持 反对

使用道具 举报

您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

小黑屋|手机版|Archiver|鱼C工作室 ( 粤ICP备18085999号-1 | 粤公网安备 44051102000585号)

GMT+8, 2024-10-2 08:29

Powered by Discuz! X3.4

© 2001-2023 Discuz! Team.

快速回复 返回顶部 返回列表