有些同学在在初学C语言时候喜欢钻牛角尖,这种喜欢钻研的精神值得肯定,但有时候反而就是因为这样错过了更精更深的知识点。
今天带着大家来简单过一下数组指针和指针数组,这两兄弟像是两座大山,重重地压在很多小白的心头上。
其实没什么可纠结的,只要按照最朴素的语言规律。后面是什么决定这整个东西最终是什么。类似于肉夹馍,说得再多它终究只是馍的一种,而不可能是肉(泪目)。
在程序中,只要定义变量,系统就会分配存储单元,我们可以用这些存储单元存数据,而地址就是这些单元的固有属性。
只不过对于数组而言,系统给它分配的不是单个存储单元,而是一段连续的存储单元,数组中有若干的元素,具体到每一个元素,它能够存储什么样的数据,或者说每一个元素都相当于什么类型的变量是由数组的基类型决定的。
比如整型数组,每一个元素就可以存一个整数,每一个元素就相当于一个整数;字符数组也是一样,每一个元素都可以存储一个普通字符,也相当于一个字符变量来使用。
那么把这样的思路类推到我们的指针数组,它的意思就是说数组中每一个元素都可以用来存储一个指针,而且每一个元素都可以相当于一个指针变量来使用。
而对于数组指针,首先它是一个指针,只不过它所指向的单元地址不是单个元素,而是一段连续存储单元的地址。
需要注意的是,对于数组而言,数组的名字(假设是arry)就是本数组的首地址,说人话就是:数组中0号元素的地址,相当于&arrr[0]。
对于整型数组中的每一个元素都可以当作一个整数来看待,所以如果去定义一个指针指向该数组的首地址,然后用指针加加去依次访问数组元素是可行的。也就是说*(arry+i)就等价于ayyr[i]。
但我们的数组指针显然要更加有格调——比如整型数组指针int(*p)[10]。对于这样子的指针,名字先结合*,所以这是一个指针,只不过它可以指向把10个整数看作一个单位的存储单元的地址。
可以把这样10个整数看作一个长度为10的一维数组,这个指针指向了整个数组,或者把这样10个整数看作若干行10列的二维数组当中某一行,这个指针指向了该二维数组的某一行。
也是基于这样的原因,所以很多人更加喜欢管它叫做行指针。
最后想给同学们普及的一个小知识点就是指针后移操作。
比如对一个指针p进行加一操作的时候,它所移动过的存储单元数是由它的基类型决定的。比如对于整型指针int *p,它后移一个单位就会跨过一个整型所占的存储空间(2字节或者4字节)。
那么对于上面提到的数组指针int (*p)[10],如果对这个指针加一,所跨过的单元就是十个整数,如果在二维数组中,它就会跨过一整行。
感谢阅读,学习使人强大。
举报/反馈