C语言二维数组中的指针问题

以一个二维数组a[3][2]为例简单介绍二维数组中关于指针的问题

一.基本含义

1.a[3][2]表示的一个三行二列的二维数组,a[0]、a[1]、a[2]分别代表第零行、第一行、第二行首元素的地址
2.数组名a本质上是一个指向一维数组的指针(数组指针),在本例中指向a数组的第零行。
注意:数组名a代表的含义也等价于&a[0]

二.&a[0]和a[0]的区别:

两者所代表的地址值都是相同的,但是它们的类型和含义是不同的。

&a[0]和a[0]都指向a数组的第零行第零列元素的首地址,但&a[0]本质是一个数组指针;而a[0]在本质上是一个指向int类型的指针

由此我们可以推出:&a[0]+1和a[0]+1代表的含义也是不相同的:

&a[0]+1指向a数组的第一行第零列的元素地址,a[0]+1指向数组的第零行第一列的元素地址。

三.取值运算符 * 在二维数组中的应用

对于指向基本数据的指针变量而言,例如a[1]+1、 *(a[1]+1)代表的是该地址元素的值;

而对于本例中的&a[1]+1或a+2而言,取值运算符作用后的结果代表的是该行第零个元素的地址,即int*型。

总结说来就是一句话:当对指向基本数据类型的指针取值时返回结果是相应的值,对其他类型的指针取值时返回结果降级为相应的指针变量。

四.相关测试代码

#include <stdio.h> 

int main()
{
    
    
	int a[3][2] = {
    
    1,2,3,4,5,6};
	printf("a = %p\n&a[0] = %p\na[0] = %p\n",a,&a[0],a[0]);
	printf("-------------------\n");
	printf("&a[0] + 1 = %p\na[0] + 1 = %p\n",&a[0] + 1,a[0] + 1);
	printf("-----取值运算符-----\n");
	printf("*(a[1] + 1) = %d\n&a[1] + 1 = %p\na + 2 = %p\n",*(a[1] + 1),&a[1] + 1,a + 2);
	return 0;
}

猜你喜欢

转载自blog.csdn.net/m0_46550452/article/details/108954271