C语言精品程序的设计第十章指针.pptVIP

  1. 1、本文档共93页,可阅读全部内容。
  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

第十章 指针;10.1 指针的概念 变量与地址;;与*运算符 含义;直接访问与间接访问 直接访问:按变量地址存取变量值 间接访问:通过存放变量地址的变量去访问变量;指针变量的初始化 一般形式:[存储类型] 数据类型 *指针名=初始地址值;;例 main( ) { int i=10; int *p; *p=i; printf(“%d”,*p); };零指针与空类型指针 零指针:(空指针) 定义:指针变量值为零 表示: int * p=0; ;例 指针的概念;例 输入两个数,并使其从大到小输出;指针变量作为函数参数——地址传递 特点:共享内存,“双向”传递;指针变量作为函数参数——地址传递 特点:共享内存,“双向”传递;swap(int *p1, int *p2) { int p; p=*p1; *p1=*p2; *p2=p; } main() { int a,b; int *pointer_1,*pointer_2; scanf(%d,%d,a,b); pointer_1=a; pointer_2=b; if(ab)swap(pointer_1,pointer_2); printf(\n%d,%d\n,a,b); };swap(int *p1, int *p2) { int p; p=*p1; *p1=*p2; *p2=p; } main() { int a,b; int *pointer_1,*pointer_2; scanf(%d,%d,a,b); pointer_1=a; pointer_2=b; if(ab)swap(pointer_1,pointer_2); printf(\n%d,%d\n,a,b); };swap(int *p1, int *p2) { int *p; *p=*p1; *p1=*p2; *p2=*p; } main() { int a,b; int *pointer_1,*pointer_2; scanf(%d,%d,a,b); pointer_1=a; pointer_2=b; if(ab) swap(pointer_1,pointer_2); printf(\n%d,%d\n,a,b); };/*ch9_32.c*/ swap(int x,int y) { int t; t=x; x=y; y=t; } main() { int a,b; int *pointer_1,*pointer_2; scanf(%d,%d,a,b); pointer_1=a; pointer_2=b; if(ab) swap(*pointer_1,*pointer_2); printf(\n%d,%d\n,a,b); };运行结果:5,9;指针运算只涉及: 算术运算 关系运算 赋值运算;指针的算术运算有如下三种: 指针与整数的加减运算 指针的加1和减1运算 指针相减运算 ;(1) 指针与整数的加、减运算 ; (2) 指针加1和减1运算 ;m = *++pn;// 即m = *(++pn),先进行赋值运算,再进行指针自加运算 m =(*pn)++; // 先给m赋值,后使指针指向的变量的值加1,也就是n+1 m = ++(*pn); // 将指针指向的变量的值加1,也就是n+1??然后赋给m ;(3) 指针相减运算 ;p?i ? p ?i?d i为整型数, d为p指向的变量所占字节数 p++, p--, p+i, p-i, p+=i, p-=i等 若p1与p2指向同一数组,p1-p2=两指针间元素个数?(p1-p2)/d p1+p2 无意义;例 p指向float数,则 p+1 ? p+1 ?4;指针变量的赋值运算 p=a; (将变量a地址?p) p=array; (将数组array首地址?p) p=array[i]; (将数组元素地址?p) p1=p2; (指针变量p2值?p1) 不能把一个整数?p, 也不能把p的值?整型变量;指针变量的关系运算 若p1和p2指向同一数组,则 p1p2 表示p1指的元素在前 p1p2 表示p1指的元素在后 p1==p2 表示p1与p2指向同一元素 若p1与p2不指

文档评论(0)

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

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

1亿VIP精品文档

相关文档