浅析C语言数组与指针.docVIP

  1. 1、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。。
  2. 2、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载
  3. 3、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
  4. 4、该文档为VIP文档,如果想要下载,成为VIP会员后,下载免费。
  5. 5、成为VIP后,下载本文档将扣除1次下载权益。下载后,不支持退款、换文档。如有疑问请联系我们
  6. 6、成为VIP后,您将拥有八大权益,权益包括:VIP文档下载权益、阅读免打扰、文档格式转换、高级专利检索、专属身份标志、高级客服、多端互通、版权登记。
  7. 7、VIP文档为合作方或网友上传,每下载1次, 网站将根据用户上传文档的质量评分、类型等,对文档贡献者给予高额补贴、流量扶持。如果你也想贡献VIP文档。上传文档
查看更多
浅析C语言数组与指针.doc

浅析C语言数组与指针   摘 要:数组和指针是C语言的两个最重要的概念,它们若结合起来使用,非常灵活,初学者往往感到无所适从,笔者根据多年的经验,利用典型实例和图表对指向一维数组的指针的定义和数组元素的引用、指针与自增自减运算符相结合的一些常见表达式的具体含义及区别、二维数组中各数组元素的多种地址表示方式及访问二维数组时如何定义指向数组元素的指针和指向某行数据的指针等进行了描述和分析,所有实例都在VC6.0环境下通过,希望初学者能快速理解和掌握。   关键词:C语言 指针 数组 自增自减   中图分类号:TP31 文献标识码:A 文章编号:1672-3791(2015)11(c)-0003-02   在C语言中数组表示一组数据类型都一样的有序数据的集合,在内存中,它们占有连续的存储单元,数组分一维数组和多维数组,一维数组是数组中最简单的,比较容易理解,用一个数组名和一个下标就能唯一地确定一个元素。多维数组理解相对抽象些,以二维数组举例,二维数组在内存中虽然是占一个连续的存储单元,但是习惯上把它写成矩阵的形式,更有助于理解其逻辑结构,二维数组每一行都可以看成一个一维数组。任何数组它们的数组名代表数组的首地址。而指针是C语言的另一个重要概念,指针代表地址,并且指针是可以移动的,对于数组和指针的使用,初学者往往感到无所适从,笔者根据多年经验,利用等级考试中的典型实例来进行描述和分析,所有实例如都在VC6.0环境下通过,希望初学者能快速理解和掌握。   1 指向一维数组指针的定义及数组元素的引用   定义指向数组元素的指针变量的方法,与定义指向变量的指针变量相同,假设定义了一个一维数组int a[5]和一个指针变量int *p,如何让指针变量指向数组呢?对于一维数组来说,只要让指针变量指向它的数组元素就可以,因为数组名a代表数组的首地址,所以p=a[0] 或p=a都表示指针指向数组的第一个元素,直接定义可以写成int *p=a。而p+1表示指向下一个元素,p-1表示指向数组上一个元素,这样,其后面第i个元素它的地址就可以表示成p+i,也可以表示成a+i。   若p指向a[0],而a[i]的地址可以用p+i或a+i表示,所以,引用数组元素的时候,既可以用普通的下标法如a[i]形式,也可以用指针法,这时*(p+i)和*(a+i)都可以表示a[i]元素。   例1: #include   void main( )   { int a[6]={10,20,30,40,50,60},*p,i=3;   p=a[1];   printf(“%d,%d\n”,a[i],p[i]);}   实例分析:此实例中,定义了一个指针指向a[1],i的值为3,输出a[3]和p[3]的值,很多初学者以为p[i]的写法是错误的,有的初学者则认为a[3]和p[3]等价,输出结果是40,40,但实际上,在C语言中,指针变量可以带下标,程序在编译时,会把下标的处理转换为地址的,p[i]处理成*(p+i),因为一开始的时候p指向a[1],那么p+i则表示往后数第三个元素,也就是a[4],故此程序输p出结果为40,50。若一开始p=a,也就是说指针指向第一个元素,那么a[i]和p[i]的值就是相等的。   2 指针与自增自减运算符的结合   指针若与自增自减运算符结合起来使用,初学者最容易出错,以自增运算符为例,若程序中出现*p++、*(p++)、*(++p)、++(*p)等算式,看起来差不多,很多初学者搞不懂它们之间的区别,殊不知“失之毫厘,谬以千里”,因为不懂它们的区别,分析程序时往往得到错误的结果。   首先,大家要知道“*”和“++”都是单目运算符,它们同一个优先级,其结合方向是自右向左的,所以*p++和*(p++)等价,根据自增运算符的“名前先取”原则,要先取*p的值,再使p自增1,即指向下一个数组元素,*(++p)则是先使p指向下一个元素,再取*p的值,这几个算式都是对所指的地址加1。 ++(*p)表示先取*p,再在这个值的基础上加1,也就是对所指的元素的值加1。   例2: #include   void main( )   { int a[5]={2,4,6,8,10},*p,**k;   p=a;k=p;   printf(“%d ”,*(p++));   printf(“%d\n”,**k);}   实例分析:此实例中,自先定义了数组a,指针p和指向指针的指针k,通过p=a和k=p语句,使指针p指向数组a的首地址,k指向指针p,接下来printf(“%d ”,*(p++))语句,是先输出*p的值为2,再使指针往后指,再输出**k的指也就是*p的值,此时,p指向4,输出4,程序的输出结果为“2 4”

文档评论(0)

lmother_lt + 关注
实名认证
文档贡献者

该用户很懒,什么也没介绍

1亿VIP精品文档

相关文档