国家级精品课程站(本书配套教学站).pptVIP

国家级精品课程站(本书配套教学站).ppt

  1. 1、本文档共30页,可阅读全部内容。
  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文档。上传文档
查看更多
国家级精品课程网站 (本书配套教学网站) 第6章 指针 6.1 地址与指针 6.2 指针运算 6.3 指针与数组 6.4 动态存储分配 6.5 指针数组 6.6 指向指针的指针 6.7 指针的初始化 6.1 地址与指针 一、地址 地址是存放信息数据的内存单元的编号。 程序中定义的任何变量、数组或函数等,在编译时都会在内存中分配一个确定的地址单元。 C规定: 变量的地址: 可以用取地址运算符‘’ 来获取 数组的地址: 可以用数组名表示 函数的地址: 可以用函数名表示 二、指针 1、指针声明的一般格式: 数据类型 *指针变量名; 举例: int * ptr; float *array; char *s1,*s2; 2、指针类型 内存地址值是固定不变的,不同类型的指针本身所占据的存储区域都一样大。 规定了用指针间接访问数据时的访问方式 为指针的算术运算提供依据 3、指针变量的初始化 指针初始化的一般格式: 指针变量名 = 数据对象; 数据对象可以是变量、数组、函数、结构等。 举例: int *ptr, i=10; ptr=i; //指向单个变量 char *sp=“string”; //指向字符串 int a[5],*ap; ap=a; //指向数组 int max(),(*fp)(); fp=max; //指向函数 图6.1 存储结构简图 6.2 指针的运算 指针运算的实质是地址的运算。 一.“*”和“”运算符 1、“”称为取地址运算符,用以返回变量的指针,即变量的地址; 2、“*”称为指针运算符,用以返回指针所指向的基类型变量的值。 “*”和“”运算符 【例】指针变量的定义和引用示例 例6.1编写交换两个变量值的函数 // Example 6-1:函数 swap(): 交换两个整形变量的值 void swap(int *xp, int *yp) { int tmp; tmp = *xp; *xp = *yp; *yp = tmp; } 图6.2 函数swap( )运算开始时的内存分配示意图 图6.3 函数swap()中的运算结束时的内存分配示意图 二、指针变量的其他运算 1、算术运算 只进行加减,完成指针移动,实现对不同数据单元的访问操作。对不同的类型,移动的单位长度不同 2、指针赋值 将一个指针赋值给另一个指针,结果是两个指针指向一个相同的地址单元。 例如, jp=a;ip=jp; ip和jp都指向a。 3、指针的关系运算 表示所指变量在内存中的位置关系 例如, ip = =jp 6.3、指针与数组 C++中,指针与数组的关系十分密切,它们都能处理内存中连续存放的一系列数据,数组与指针在访问内存时采用同样的地址计算方法。 例如:若程序中同时声明指针和数组: int *pa,a[10]; 并且通过指针赋值运算; pa=a;或pa=a[0]; 则pa指向数组a的首地址。 这时: a[i] =*(a+i)= *(ptr+i) 例6.2编写一个字符串复制函数 // Example 6-2:复制字符串 void mystrcpy(char *destin, char *source) { while(*source!=0) // 如果*source==0表示原字符串结束 { *destin = *source; // 复制字符 source ++; // source移向原字符串中的下一个字符 destin ++; // destin移向新字符数组的下一位置 } *destin = 0; // 在新字符串尾部添写一个结束符0 }。 例6-3 数组清零 void clear_array(float *ptr, int len) { // ptr指向数组的首地址,len是准备清零的数组元素个数 float *qtr = ptr+len; // qtr指向被清零的最后一个数组元素之后的下一位置 while(ptrqtr) { *ptr = 0.0; // 将指针所对应的数组元素置0 ptr++; // 指针向后移动一个单位 } } 6.4 动态存储分配 1、运算符new (1)为申请所需的内存 指针 = new 类型(初值); (2)为数组申请内存: 指针 = new 类型[元素数]; 2、运算符delete (1)释放先前申请到的存储块 delete 指针; (2)释放数组的空间 delete []p; 例6-4 利用动态数组求斐波那挈数列的前n项 #include iostream

文档评论(0)

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

本账号下所有文档分享可拿50%收益 欢迎分享

1亿VIP精品文档

相关文档