谭浩强c语言系列第八章课件.pptVIP

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

第8章 指针;一、指针的概念 指针是一种存放变量地址的变量;二、变量的指针和指向变量的指针变量 定义 类型名 *指针变量名 例: int *p1; float *p2; char *p3; 说明: p1、p2、p3是用户自定义标识符,“*”说明p1、 p2、p3是指针类型的变量 类型名说明了指针变量所能指向的变量类型;指针变量的赋值 使用取地址运算符,把地址值赋给指针变量 例: int i, *p; p=i; /*将变量i的地址赋给指针p*/ “”:地址运算符,运算对象是一个变量 运算对象(i)的类型与指针变量(p)的类型相同 指针变量赋NULL值 例:p1=NULL; 表示指针p1赋“空值” 把指针变量的值直接赋给指针变量 例:int *p1,*p2,i; p1=i; p2=p1; /*p1、p2均指向变量i*/;指针的使用 :地址运算符 *:指针运算符 使用说明: “*”出现的位置不同含义也不相同;例1:用指针实现两数的交换 错例:;错例;三、一维数组与指针 一维数组与指针的关系 一维数组和数组元素的地址 例:int a[10], *p; p=a; /*与p=a[0]等价*/ 同理: 若p=a+1; 则p存放a[1]的地址 通过一维数组名所代表的地址引用数组元素 例:int a[10], *p; a 代表a[0]的地址; a+i 代表a[i]的地址;通过指针引用数组元素 例:int a[10], *p=a; /*定义的同时初始化*/ 则a[0]的地址赋给了p,即p指向a[0]; p+i 与a[i]等价;则*(p+i)与a[i]等价 通过带下标的指针引用数组元素 int a[10],*p=a; p指向a[0],则*(p+i)可写成p[i] 总结:在p=a;的条件下,对a[i]的引用方式还可写为:*(a+i)、*(p+i)、p[i];指针变量的运算 p++:p指向下一元素 *p++:等价与*(p++),++后置,先取p值,做*p的运算后,p再自加 *(p++)与*(++p)的区别类似于“++”前置和后置的区别 区别(*p)++、*(p++) (*p)++:表示p指向的元素值加1, *(p++):取出*p后,p指向下一地址单元的元素 同理:p可自减;使用注意 a与a[0]的含义不同,a表示地址,a[0]表示数组元素 p是指针变量,可以对其进行+、-、和赋值运算 如:p++; p=a; p=a[i]等等 数组名a表示一个地址常量,即一个常量指针,不能改变它的值 如:a++; a=p; a+=i; 是非法的;举例说明 若有以下定义和语句,且0=i10,则对数组元素的错误引用是: int a[ ]={1,2,3,4,5,6,7,8,9,0},*p,i; p=a; A. *(a+i) B. a[p-a] C. p+i D. *(a[i]) 若定义同上,对数组元素地址的正确表示是 A. (a+1) B. a+ + C. p D. p[i];四、指针与函数 形参、实参都用数组名 与第8章的内容完全一致,传递数组首地址 实参用数组名,形参用指针变量 实参用指针变量,形参用数组名 形参、实参都用指针变量;int max,min; void max_min(int *array,int n) { int *p,*array_end; array_end=array+n; max=min=*array; for(p=array+1;parray_end;p++) { if (*pmax) max=*p; else if(*pmin) min=*p; } return; };int max,min; void max_min(int array[ ],int n) { int i; max=min=array[0]; for(i=1;in;i++) { if (array[i]max) max=array[i]; else if(array[i]min) min=array[i]; }

您可能关注的文档

文档评论(0)

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

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

1亿VIP精品文档

相关文档