您的位置:首页 > 编程语言 > C语言/C++

C语言的指针(进阶篇章之二)

2016-06-03 12:34 218 查看

指针遇到数组,不得不说的“秘密”

说起数组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 4000
.com/writer#/notebooks/4124910/notes/4176907
内容来自用户分享和网络整理,不保证内容的准确性,如有侵权内容,可联系管理员处理 点击这里给我发消息
标签: