【C/C++】C语言二维数组名与&、*的组合使用

前言

  1. 本文是作者查阅资料后根据代码演练,得出的结论。结论仅用于知识点的关联总结。
  2. 本文的 & 统一称为取地址操作,* 统一称为解引用。关于解引用,可参考:解引用的理解
  3. 本文不再介绍二维数组与一维数组的关系

1. 一个二维素组在内存中的结构

int array[][3] = {{1,2,3},{4,5,6}};

在这里插入图片描述

2. 数组名 & * 三者的组合用法

会惊奇的发下,以下的表达式,都输出了同一个地址值

int main() {
        int  array[][3] = {{1,2,3},{4,5,6}};
        printf("array           地址 : %p \n", array);
        printf("*array          地址 :%p \n", *array);
        printf("array[0]        地址 : %p \n", array[0]);
        printf("&array[0]       地址 : %p \n", &array[0]);
        printf("&array          地址 : %p \n", &array);
        return 0;
}

2.1 array

二维数组名array%p代表的是数组首元素的首地址,即a[0]的地址

2.2 array[0]

由2.1可以推论,array[0]为二维数组的首元素,%p代表二维数组的首元素的(一维数组)中的首元素的地址,即array[0][0] 的地址

2.3 &array

对二维数组进行取地址操作 %p 代表 array 的地址

2.4 *array

array[0]的语法糖,根据:见视频 04:54,结论见2.2

2.5 &array[0]

由2.2可以推论,array[0]为二维数组的首元素,取地址操作见2.6的图
PS:& 取地址操作,%p即为地址值

2.6 描述成图

在这里插入图片描述

3. 代码证明

按层*进行运算, 即解引用,图片上就是按层缩进,直到找到值1。
如 &array 就是需要四次解引用才能找到值1

int main() {
        int  array[][3] = {{1,2,3},{4,5,6}};
        printf("array           地址 : %p        | 解引用:  略                         \n", array);
        printf("*array          地址 :%p        | 解引用:  *(*array)   : %d    \n", *array, *(*array));
        printf("array[0]        地址 : %p        | 解引用:  *(array[0]) : %d           \n", array[0], *(array[0]));
        printf("&array[0]       地址 : %p        | 解引用:  *(&array[0]): %d   地址:  %p      | 解引用 : *(*(&array[0])) :  %d \n", &array[0], *(&array[0]), *(&array[0]), *(*(&array[0])));
        printf("&array          地址 : %p        | 解引用:  *(&array)   : %d   地址:  %p      | 解引用 : *(*(&array))    :  %d    地址 : %p | 解引用 *(*(*(&array[0]))) : %d \n",
         &array, *(&array), *(&array), *(*(&array)), *(*(&array)),  *(*(*(&array))));
        return 0;
}

后记

对于数组,C语言提供了方便,也可以说不严格,比如如下函数。

char name[51];
scanf(%s, &name);
// scanf(%s,name); 跟上面的效果是等价的

作者也只是在大学简单得学了C语言,现在回过头来看数组名的解释对于初学者很不友好,作者认为没有必要过分纠结这个事情,探索只是兴趣使然,实际使用的话仅记住结论即可。

  • 3
    点赞
  • 19
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值