实例分析用指针访问二维数组的几种方法

原创 2015年07月10日 11:06:45

之前对数组的概念一直没有理解透彻,只觉得数组名就是个常量指针而已,用法和基本的指针差不多。所以当我尝试用二级指针去访问二维数组时,就经常会出错。下面就是刚开始写的一个错误的程序:

copycode.gif

#include <stdio.h>


int main()

{

    int iArray[2][3] =        {{1,2,3},{4,5,6}};

    int **pArray = NULL;

    

    pArray = iArray;

    

    printf("pArray[0] = %d\n",*pArray);           (1)

    printf("array[0][0] = %d\n", pArray[0][0]);   (2)

    printf("array[1][2] = %d\n", pArray[1][2]);   (3)

    

    return 0;

}

copycode.gif

 

    (1)当执行第一步的时候打印的结果为: pArray[0] = 1,即为array[0][0]的值,而**pArray则是去访问地址为1的地址空间中的数据,自然会出段错误。

      (2) 当执行第二步和第三步时系统会报错:其实这里错误的原因是访问了不该访问的地址空间.(pArray[0][0]其实就是 *(*(pArray + 0)+0)).

指向数组的指针和指向指针的指针也大不一样。它们俩最明显的不同就是表现在指针步进的时候。我们知道指针在进行++运算的时候,跨越的实际地址取决于指针指向的数据类型:对于一般的32位机来说,假如指向的是int型数据,跨越的实际地址就是4,指向的是指针型数据,跨越的实际地址也是4,当指向的是数组类型的时候,跨越的实际地址就是数组的长度了。


     其实用指针访问二维数组可以直接用一级指针就可以了。比如下面这个程序:

copycode.gif

int main()

{

    int iArray[2][3] =        {{1,2,3},{4,5,6}};

    int *pArray = NULL;

    

    pArray = iArray;

    

    printf("array[0][0] = %d\n", *pArray);

    printf("array[1][2] = %d\n", *(pArray + 1 * 3 + 2));

    

    return 0;

}

copycode.gif

    因为数组本身在地址空间中就是连续排列的,根据行数和列数,我们自己计算出访问单元的地址偏移量就可以用一级指针轻松遍历二维数组中的所有数据了。


我们还可以尝试用指向数组的指针来访问二维数组的成员。下面就是事例程序:

copycode.gif

int main()

{

    int iArray[2][3] =        {{1,2,3},{4,5,6}};

    int (*pArray)[3] = NULL;

    

    pArray = iArray;

    

    printf("array[0][0] = %d\n", pArray[0][0]);

    printf("array[1][2] = %d\n", pArray[1][2]);

    

    return 0;

}

copycode.gif


     简单分析一下这个程序:我们知道[]运算符的结合方向是由左向右,pArray[1][2]就等价于(* (pArray + 1))[2],而由于pArray是数组指针,而且数组的长度为3,所以* (pArray + 1)就表示iArray[1]这个数组,则pArray[1][2]则就完全等价于iArray[1][2]


     如果非得想用二级指针来访问二维数组的话,我们还得借用指针数组(数组内存储的都是指针类型的数据),下面是事例程序:

copycode.gif

int main()

{

    int iArray[2][3] =        {{1,2,3},{4,5,6}};

    int *ipArray[2] = {iArray[0], iArray[1]};

    int **pArray = NULL;

    

    pArray = ipArray;

    

    printf("array[0][0] = %d\n", pArray[0][0]);

    printf("array[1][2] = %d\n", pArray[1][2]);

    

    return 0;

}

copycode.gif


     由于二级指针要跳两次,所以中间还需要额外的存储一级指针的空间。所以一般不建议用二级指针去访问二维数组。

版权声明:本文为博主原创文章,未经博主允许不得转载。

17、指针与二维数组--二维数组元素利用指针的三种输出方法

二维数组元素利用指针的三种输出方法

关于用指针方式访问二维数组的问题

关于用指针方式访问二维数组的问题首先,以二维数组a[2][3]为例,a是由数组a[0]、a[1]组成的一维数组,因此,数组名a可以看作是a[0]、a[1]的首地址,即a==&a[0]。 然后,对于二维...

二维数组和指针

二维数组和指针⑴ 用指针表示二维数组元素。要用指针处理二维数组,首先要解决从存储的角度对二维数组的认识问题。我们知道,一个二维数组在计算机中存储时,是按照先行后列的顺序依次存储的,当把每一行看作一个整...
  • iu_81
  • iu_81
  • 2007年09月12日 19:45
  • 54814

二维数组的指针访问方法

前几天参加迅雷的笔试遇到了这种题,认真实验了下,代码如下#include using namespace std;const int row = 2, col = 3;int main(){ i...

二维数组的五种指针表示及指针数组

#include #include int main(void) { puts("Hello World!!!"); /* prints Hello World!!! */ //二维数组的五...

C语言:定义指向二维数组的指针变量

C语言:定义指向二维数组的指针变量标签: C语言 二维数组 指针 by 小威威1.引入我们知道,要在函数中处理数组,一般要给函数传递指针。那么,对于一维int数组a[10],我们可以定义一个in...
  • linwh8
  • linwh8
  • 2015年12月17日 21:14
  • 7726

C语言教学--二维数组和指针的理解

对于初学者对二维数组和指针的理解很模糊, 或者感觉很难理解, 其实我们和生活联系起来, 这一切都会变得清晰透彻.   我们用理解一维数组的思想来理解二维数组, 对于一维数组,每个箱子里存放的是具体的...

C语言指针引用二维数组

最近看谭浩强的《C程序设计》,第248页 例8.11 看到这里例子感觉有点懵,所以根据这个例子自己总结了下: 一.不用取地址符和指针 1.二维数组的元素: a[0][1] 2.二维数组的地址:...

使用指针访问数组元素

C++语言中,指针和数组密切相关.特别是在表达式中使用数组名时,该名字会自动 转换为指向数组第一个元素的指针:int ia[]={0,2,4,6,8};int *ip=ia;  //ip points...

指针遍历二维数组的三种方式

#include void func1(int p[][3], int row, int col){ //第一种遍历方式 传递 二维数组名(行指针) //通过下标遍历 简单明了 ...
  • AXuan_K
  • AXuan_K
  • 2016年07月18日 16:47
  • 2309
内容举报
返回顶部
收藏助手
不良信息举报
您举报文章:实例分析用指针访问二维数组的几种方法
举报原因:
原因补充:

(最多只允许输入30个字)