指针遇到数组,不得不说的“秘密”
- 说起数组array[i]来,我们都知道:数组名“array”是数组的唯一标识符,数组名代表数组首元素的地址。
而今天的主角——指针,则是用于存储地址,它在C语言使用中和数组名是紧密的联系在一起。
一、数组的访问方式
- 一般来说采用下标/偏移法和指针法来访问数组元素的。
- 一维数组比较常见,而且简单易懂。(随便提一下:二维数组元素的表示方法是:数组名称[行][列],对于m 行n 列的二维数组,a[0][0] 是数组的第一个元素,a[m-1][n-1] 是最后一个元素。)
我们以二维数组为例–
eg:二维数组array[2][3]中,在内存储中存储形式如下图所示:
#include <stdio.h>
int main()
{
int a[2][3] = {{1,2,3},{10,20,30},{100,200,300}};
for(int i=0; i<3; i++)
{
for(int j=0; j<4; j++)
{
printf("%p ",&a[i][j]);
}
putchar(10);
}
//研究数组名a的大小
printf("a = %p\n",a);
printf("a + 0 = %p\n",a+0);
printf("a + 1 = %p\t",a+1);
printf("a + 2 = %p\n",a+2);
//研究数组a的每个元素的大小
printf("a[0] = %p\n",a[0]);
printf("a[1] = %p\t\t",a[1]);
printf("a[1] + 1 = %p\t",a[1]+1);
//研究二维数组到一维数组的关系化
printf("*(a+1)+1) = %d\t",*(a+1)+1));
printf("*(*(a+1) + 1) = %d\n",*(*(a+1)+1));
printf("&a[1] +1 = %p\n",&a[1]+1);
return 0;
}
从程序中我们可以总结出:
a //表示是数组下标为0的那一行的首地址
a+1 //表示是数组下标1的那一行的首地址[<=>&a[1] ]
a[1] //<=>a[1]+0,也是a[1][0]元素的地址
a[1]+1 //指的也是a[1][1]元素的地址
*(a+1)+1 //指的也是a[1][1]元素的地址
((a+1)+1) //指的是元素a[1][1]值
*( a[1]+1) //指的是元素a[1][1]值
二、指针与数组参数
- 指针与数组参数分为四种情况(这里一一列举出来,就不举例子了):
【a】实参是数组,形参也是数组
主调函数:
int a[40];
function(a);
被调函数:
function(int a[]) {……}
【b】实参是数组,形参是数组指针
主调函数:
int a[40];
function(a);
被调函数:
function(int *p) {…}
【c】实参是数组指针,形参是数组指针
主调函数:
int a[40];
int *p=a;
function(p);
被调函数:
function(int *q) {......}
【d】实参是数组指针,形参是数组
主调函数:
int a[40];
int *p=a;
function(p);
被调函数:
function(int a[]) {......}
三、指针与字符串
- 重点的是指针数组和数组指针
注:由于还没有说到字符串,这里就先起个头。望见谅。下章讲字符串。谢谢!
【文章来自本人的简书】
http://www.jianshu.com/writer#/notebooks/4124910/notes/4176907