




版权说明:本文档由用户提供并上传,收益归属内容提供方,若内容存在侵权,请进行举报或认领
文档简介
1、指向二维数组的指针 一. 二维数组元素的地址 为了说明问题, 我们定义以下二维数组: int a34=0,1,2,3, 4,5,6,7, 8,9,10,11; a为二维数组名, 此数组有3行4列, 共12个元素。但也可这样来理解, 数组a由三个元素组成: a0, a1, a2。而它中每个元素又是一个一维数组, 且都含有4个元素 (相当于4列, 例如, a0所代表的一维数组所包含的 4 个元素为 a00, a01, a02, a03。如图5.所示: a a0 0 1 2 3 a1 4 5 6 7 a2 8 9 1011 图5. 但从二维数组的角度来看, a代表二维数组的首地址, 当然也可看成是二
2、维数组第0行的首地址。a+1就代表第1行的首地址, a+2就代表第2行的首地址。 如果此二维数组的首地址为1000, 由于第0行有4个整型元素, 所以a+1为1008, a+2 也就为1016。如图6.所示 a34 a (10000 1 2 3 a+1 (10084 5 6 7 a+2 (10168 9 1011 图6. 既然我们把a0, a1, a2看成是一维数组名, 可以认为它们分别代表它们所对应的数组的首地址, 也就是讲, a0代表第 0 行中第 0 列元素的地址, 即&a00, a1是第1行中第0列元素的地址, 即&a10, 根据地址运算规则, a0+1即代表第0行第1
3、列元素的地址, 即&a01, 一般而言, ai+j即代表第 i行第j列元素的地址, 即&aij。 另外, 在二维数组中, 我们还可用指针的形式来表示各元素的地址。如前所述, a0与*(a+0等价, a1与*(a+1等价, 因此ai+j就与*(a+i+j等价, 它表示数组元素aij的地址。 因此, 二维数组元素aij可表示成*(ai+j或*(*(a+i+j, 它们都与aij等价, 或者还可写成(*(a+ij。 另外, 要补充说明一下, 如果你编写一个程序输出打印a和*a, 你可发现它们的值是相同的, 这是为什么呢? 我们可这样来理解: 首先, 为了说明问题, 我们把二维数组人为地
4、看成由三个数组元素a0, a1, a2组成, 将a0, a1, a2看成是数组名它们又分别是由4个元素组成的一维数组。因此, a表示数组第 0行的地址, 而*a即为a0, 它是数组名, 当然还是地址, 它就是数组第0 行第0 列元素的地址。 二. 指向一个由n个元素所组成的数组指针 在Turbo C中, 可定义如下的指针变量: int (*p3; 指针p为指向一个由3个元素所组成的整型数组指针。在定义中, 圆括号是不能少的, 否则它是指针数组, 这将在后面介绍。这种数组的指针不同于前面介绍的整型指针, 当整型指针指向一个整型数组的元素时, 进行指针(地址加1运算, 表示指向数组的下一个元素,
5、此时地址值增加了2(因为放大因子为2, 而如上所定义的指向一个由3个元素组成的数组指针, 进行地址加1运算时, 其地址值增加了6(放大因子为2x3=6, 这种数组指针在Turbo C中用得较少, 但在处理二维数组时, 还是很方便的。例如: int a34, (*p4; p=a; 开始时p指向二维数组第0行, 当进行p+1运算时, 根据地址运算规则, 此时放大因子为4x2=8, 所以此时正好指向二维数组的第1行。和二维数组元素地址计算的规则一样, *p+1指向a01, *(p+i+j则指向数组元素aij。 例1 int a3 4= 1,3,5,7, 9,11,13,15, 17,19,21,23
6、 ; main( int i,(*b4; b=a+1; /* b指向二维数组的第1行, 此时*b0或 *b是a10 */ for(i=1;i<=4;b=b0+2,i+/* 修改b的指向, 每次增加2 */ printf("%dt",*b0; printf("n" for (i=0; i<2; i+ b=a+i; /* 修改b的指向, 每次跳过二维数组的 一行 */ printf("%dt",*(bi+1; printf ("n" 程序运行结果如下: 9 13 17 21 3 11 19指向二维数组的指针
7、.的一点理解2009-05-26 13:36例:int w23,(*pw3;pw=w;则下列错误的是a.*(w0+2b.*(pw+12 c.pw00d.*(pw1+2今天晚上因为这道小题仔细研究了C的多维数组和指向多维数组的指针(归根结底,这两个东西完全一致)上面的题是二维的,当你理解了这个题之后,多维的自然就通了。要解决这类的问题,需要深刻理解"*,&,"这三个符号在对多维数组操作时的作用,下面就讲一下他们在多维数组中的作用。(1*:得到对应指针中的存储的"东西"(一维的时候,这个东西是最体的值;二维时,这个东西就是指向一维数组的一个指针,三维
8、时。多维时。)。(2&: 得到相应变量的地址。(3:表示相对于当前指针的偏移量。比如:例1:对int a5,则a3表示相对于a偏移3个位置:即:a3 = *(a+3 /*这是理解的关键例2:对int a54,则a32表示相对a3偏移2个位置,而a3表示相对于a偏移3个位置:即:a32= *(a3+2 = *(*(a+3+2例3:对int a543,则a321表示相对a32偏移1个位置,a32相对a3偏移2个位置,而a3表示相对于a偏移3个位置:即:a321= *(a32+1 = *(*(a3+2+1 = *(*(*(a+3+2+1 对于更多维的以此类推:。这里面是用数组名即指针常量。对
9、于一个指针变量的情况相同,如:对int a5,*p,p=a; 则a3=p3=*(p+3;对int a54,(*p4,p=a; 则a32=p32=*(p3+2=*(*(p+3+2;注意:上面得到的最终的结果的最终形式是类似:*(*(p+3+2,这个式子最内部的括号中的维度最高,而在展开内部括号时,偏移量需要乘上维度的权值(即每一维中存储的元素的个数)例如:对于int a54,(*p4,p=a; 则a32=p32=*(p3+2=*(*(p+3+2=>*(*(p+3×4+2=*(*p+3×4+2 /p为指向二维数组的指针,*p为指向一维的指针。需要深刻理解这一点。对于上面的
10、题来说,还有个知识点:就是的优先级高于*,因此对于B选项:*(pw+12 等价于:*(pw+12 按照例1的作法 =>*(*(pw+1+2 即:*(*(pw+3=*(*(pw+3+0=*(pw3+0=pw30=w30(已经越界.注意:对于an代表取出(a+n位置的值,即an=*(a+n 。所以本题:(pw+12=*(pw+1+2其他的选项均可参照上面的对的讲解,并结合*,& 灵活转换,确定是否越界:对于a. *(w0+2 = w02 参照例2(即:"a32= *(a3+2" )逆运算c. pw00=w00d. *(pw1+2 同选项a作法一样(因为pw与w实质
11、是一样的,不同的是,w是一个指向一维数组的指针常量,而pw是指向一维数组的指针变量。说白了,就是w不能改变,而pw可变仅此而已)指针数组:我给个短语你!漂亮的女孩,用一个形容词漂亮来修饰一个女孩而你可以把指针数组理解成(改成形容词!指针的数组,或者,指针构成的数组,这样理解就很方便拉!也就是说,数组还是数组。只不过内容成了指针罢拉!或者说女孩还是女孩,只不过漂亮而已!(如果还不知道,我打你pp,你就知道数组中可以放整数,字符,什么的,他就不能放地址呀!)所以:int* a4,int*只是类型,放在一起看!表示的是数组里面存贮的是指向某些整形数据的指针!数组指针我在给个短语你:女孩出嫁,(好好的
12、女孩就嫁人了,!)好好的数组就嫁给指针拉!没事非要和指针扯上关系!晕!当然他也是有目的的。这多半用在动态生成的多维数组,反正我用的少,觉得没多大意思!你接触数组指针,你猜是什么时候!我觉得并不是到拉二维数组!当然实际要考试什么的都是到拉二维数组!当你开始接触:int a10;int *p;p=a;这个时候,你应该明白,你就接触到拉。数组指针,其实说白拉,他就是把数组指针化!经过上面的,p就指向数组a拉,可以操作a拉有了这个知识二维就很好明白int a1010;int (*p10;p=a;(p=&a0,这样就更能体现指针的含义,表示指针p指向数组a不废话了!等下说多拉又被人bs!指针数组
13、与数组指针(2009-12-03 10:40:22转载标签: 杂谈 分类: C语言 指针数组 typename *pn : 定义了一个数组,数组包含了n个指针变量p0,p1.pn-1;例如: *p3 = "abc", "defg" sizeof(p = 3*4 =12 (p 为数组名代表整个数组 *p1 = "abc".p = &p0 (p+1=&p1 , 符合一般数组的特性,除了数组中的元素是指针以外,和一般的数组没什么区别。数组名p 是个指针常量,不能直接进行指针运算,不过可以传递给函数来进行。可以通过px (0&
14、lt;=x 来对指针数组进行赋值,如: p2 = "hijklm" 否则,对数组中的每个指针进行初始化, 必须先分配 px 所指向的内存空间! 必须对分配结果进行判断 if ( px=(typename *malloc(n * sizeof(typename = NULL 失败。 指向数组的指针(以二维数组为例 typename (*pn: 定义了一个指向含 n个数据元素的二维数组的指针;二维数组int num24 可以看作是两个 num4 的数组构成, 数组名num是个指向第一个元素 ,num0 是指向 num00, num01, num02, num03 ,num1同理
15、。num = num0 = &num00; num+1 = num1 = &num10 ; 二维数组名可以看做是一个指向指针数组的指针,num-> num0, num1 -> num00.;定义:int (*p4 ; p = num; -> p = num0 p+1 = num1; sizeof(p = 4; sizeof(*p = 4*4 (这里*p是不是和上面的 sizeof(p (定义:int *p4 很像; sizeof(*(p+1 = 16; sizeof(num = 2*4*4=32, p所指向的4*sizeof(int bytes的空间的整体,
16、因为数组是顺序存储结构,所以 p+1 就指向第二列的第一个元素(跨过了4个int的地址空间);因为p是指向一个数组一行元素的整体的指针,如果要对数组每个元素进行读写,需要用强制转换,把指向4int的指针转换为一个指向1int的指针,(实际上就是把p所指向的第一个地址传递给一个int *q 指针,因为数组是顺序存储结构,所以只需要知道首地址和长度就可以了)然后用该指针来遍历数组。可以把指向数组的指针或数组名传递给函数来对二维数组进行操作, 下面是分别用两种方法来实现print_array 函数:1. void print_array1(int (*p_num4 2 void print_arra
17、y2(int (*p_num4, int n int *q, i; int *q, i; q=(int *p_num; q = (int *p_num; / 指针类型强制转换for (i =0;i<4;i+printf("%dn", *q+ for(i = 0; i< (4*n;i+. 两种方法实质上一样,方法1需要在主函数中需要 进行 for ( i =0; i < 2; i+ print_array1(p; p+ (p 是指向二维数组的指针 也就是每一行进行一次调用,方法二是从数组头开始,按照存储顺序依次print。因为数组存储的方式也是先行后列,所以
18、两种打印的方式输出一样。 注意一点:因为数组名是常量指针,所以在方法1中是不可以直接利用数组名传递给函数的,因为num+是不合法的!二维数组、指针数组、数组指针、指向指针的指针 1、二维数组:二维数是按一定的顺序访问地址,把元素按行存放。2、指针数组:一个数组,其元素均为指针类型数据,称为指针数组,也就是说,指针数组中的每一个元素都相当于一个指针变量。指针数组比较适合于用来指向若干字符串。按一般方法,字符串本身就是一个字符数组,因此要设计一个二维的字符数组才能存放多个字符串。但在定义二维数组时,需要指定列数,也就是说二维数组中每一行中包含的元素个数(即列数)相等。而实际上各字符串长度一般是不相等的。如按最长的字符串来定义列数,则会浪费许多内存单元。二维数组是按一定的顺序访问地址,指针数组中全部存放的是指向地址的指针。指针数组指向的字符串所存储的空间是可以不等的,也就是说每个字符串有多长,那 么总的字符长度就是它们所占用的和。而在
温馨提示
- 1. 本站所有资源如无特殊说明,都需要本地电脑安装OFFICE2007和PDF阅读器。图纸软件为CAD,CAXA,PROE,UG,SolidWorks等.压缩文件请下载最新的WinRAR软件解压。
- 2. 本站的文档不包含任何第三方提供的附件图纸等,如果需要附件,请联系上传者。文件的所有权益归上传用户所有。
- 3. 本站RAR压缩包中若带图纸,网页内容里面会有图纸预览,若没有图纸预览就没有图纸。
- 4. 未经权益所有人同意不得将文件中的内容挪作商业或盈利用途。
- 5. 人人文库网仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对用户上传分享的文档内容本身不做任何修改或编辑,并不能对任何下载内容负责。
- 6. 下载文件中如有侵权或不适当内容,请与我们联系,我们立即纠正。
- 7. 本站不保证下载资源的准确性、安全性和完整性, 同时也不承担用户因使用这些下载资源对自己和他人造成任何形式的伤害或损失。
最新文档
- 检验科室承包合同
- 建筑工程施工合同书合同
- 房屋买卖按揭合同书
- 工业品买卖合同经典
- 交通标牌采购投标合同
- 存量房买卖房屋租赁合同出租
- 非公开协议合同
- 鲜奶代加工合同协议书
- 挖机按天施工合同协议书
- 公司直播协议合同
- 本科成考试题及答案政治
- 中国桂花茶行业市场前景预测及投资价值评估分析报告
- 四年级语文国测模拟试题 (1)附有答案
- 部编 道法 六下 第5课、应对自然灾害(课件+教案+习题+知识点)【2套实用版】
- Chap-17垄断竞争(经济学原理 中英文双语)
- 新课程标准下的教学规范:5.山东省初中历史课堂教学基本要求
- “二级甲等妇幼保健院”评审汇报材料二级甲等妇幼保健院(最新)
- 单相变压器精品课件
- 最新EXCEL上机操作练习题1
- 换发药品生产许可证自查报告格式
- 吊篮四方验收表
评论
0/150
提交评论