行指针 二维数组 c语言,读书笔记-c语言-二维数组的指针和行指针

1、二级地址与一级地址是完全不同的两种地址。二级指针变量与一级指针变量也是完全不同的两种指针变量,二者决不能互换使用,更不能彼此间赋值。

2、一维数组的数组名是假想的指针变量,他是假想的一级指针变量。二维数组名也是假想的指针变量,他是二级指针变量。数组在内存中是“线性存储、按行排列”的。b[1][0]是紧挨在b[0][3]之后的下一个空间,b[2][0]是加你在b[1][3]之后的下一个空间。举例:int b[3][4]={ {1,2,3,4},{5,6,7,8},{9,10,11,12} }

以下几点必须记住:

(1)b是数组名(二维数组的数组名)。

(2)b是一个假想的“二级指针变量”,它“保存”另一指针变量的地址(地址的地址)。

(3)指针变量b所“保存”的值为数组首地址,即数组第0行的地址,数值上与元素b[0][0]的地址相等,不过它是二级的。

(4)指针变量b本身的地址(b所在内存字节编号)是二维数组的地址,数值上与元素b[0][0]的地址相等。

(5)b值不可被改变,是常量。

3、c语言规定,赋值语句中,只有级别相同的指针变量才能彼此之间赋值。

4、谁来保存二维数组名b的 地址呢。需要定义另外一种专用的指针变量来专门保存二维数组名的这种“二级”地址。这种指针变量称为行指针。定义如下:int  (*q)[4];*() [4]三者缺一不可。

具体含义是:定义了一个指针变量q,保存二级地址,它可以指向每行4个元素的整型二维数组的一行。注意:行指针指向的是二维数组的一行,而不是二维数组本身,行指针只能保存一行的地址(一行是个一维数组),而不是保存二维数组的地址。因为二维数组的地址是三级的(一维数组的地址是二级的,数组元素的地址是一级的)。准确的说法是“行指针指向二维数组的一行或行指针保存二维数组的首地址(首地址就是指第0行这一行的地址);”

注意行指针和二维数组都有“一行几个元素”的概念,在指针变量赋值时要小心。如果“一行几个元素“不同,即使指针变量的级别相同也是不能赋值的。例如:int x[3][10];int  (*q)[4];q=x;

q=b;这样就可以将b中的二位地址[[1000]]保存到变量q中了

5、二维数组名+(-)n或行指针+(-)n=地址值+(-)数组每行元素个数*每元素字节数*n

b+1或q+1的值为:二级地址[[1016]](注意计算b+1并没有改变b的值)。

b+2或q+2的值为:二级地址[[1032]](注意计算b+2并没有改变b的值)

6、行指针与二维数组名是等效的.

把q[i]或b[i]看成一个整体,如下所示:q[i][j]<=>*(q[i]+j)   b[i][j]<=>*(b[i]+j)

再将q[i]变换为*(q+i),将b[i]变换为*(b+i):

q[i][j]<=>*(*(q+i)+j)     b[i][j]<=>*(*(b+i)+j)

因此,当q与b的值相等时,q[i][j]就是b[i][j],一个[]的形式也相同:q[i]就是b[i]。

你可能感兴趣的:(行指针,二维数组,c语言)