第8章大学C语言教材资料讲解

上传人:yuzo****123 文档编号:137917388 上传时间:2020-07-12 格式:PPT 页数:87 大小:1.92MB
返回 下载 相关 举报
第8章大学C语言教材资料讲解_第1页
第1页 / 共87页
第8章大学C语言教材资料讲解_第2页
第2页 / 共87页
第8章大学C语言教材资料讲解_第3页
第3页 / 共87页
第8章大学C语言教材资料讲解_第4页
第4页 / 共87页
第8章大学C语言教材资料讲解_第5页
第5页 / 共87页
点击查看更多>>
资源描述

《第8章大学C语言教材资料讲解》由会员分享,可在线阅读,更多相关《第8章大学C语言教材资料讲解(87页珍藏版)》请在金锄头文库上搜索。

1、第8章 指针,第8章 指针,C程序设计中使用指针可以: 使程序简洁、紧凑、高效 有效地表示复杂的数据结构 动态分配内存 得到多于一个的函数返回值,指针是一种特殊的数据类型; 指针概念是C语言中较难理解和较难掌握的概念。,本章内容,8.1 概述 8.2 指针变量 8.3 指针与函数 8.4 指针与数组 8.5 指针与字符串 8.6 指针数组 8.7 指向指针的指针 8.8 main函数的参数 8.9 动态存储分配,8.1指针的概念,要明白什么是指针,必须弄清楚数据在内存中是如何存储的,又是如何读取的。,内存区的每一个字节有一个编号,这就是“地址” 。如果在程序中定义了一个变量,在对程序进行编译时

2、,系统就会给这个变量分配内存单元。,2.指针与指针变量 指针:一个变量的地址 指针变量:专门存放变量地址的变量 在语言中,指针是一种特殊的变量,它是存放地址的。,2000,指针,指针变量,变量的内容,变量的地址,3.变量的直接访问与间接访问 直接访问:按变量地址存取变量值 间接访问:通过存放变量地址的变量去访问变量,例 i=3; -直接访问,3,例 *i_pointer=20; -间接访问,20,两种访问方式:相当于某人甲(系统)要找某人乙(变量)来类比,有两种方法: (1)甲知道乙在何处,直接去找就是(即直接访问)。 (2)甲不知道乙在哪,但丙(指针变量)知道,此时甲可以这么做:先找丙,从丙

3、处获得乙的去向,然后再找乙(即间接访问)。 指针变量与其所指向的变量之间的关系,4.两种访问方式的特点,8.2 指针变量,8.2.1指针变量的定义 一般形式:存储类型 数据类型 *指针名;,合法标识符,指针变量本身的存储类型,指针的目标变量的数据类型,表示定义指针变量 不是*运算符,例 int *p1,*p2; float *q ; static char *name;,注意: 1、int *p1, *p2; 与 int *p1, p2; 2、指针变量名是p1,p2 ,不是*p1,*p2 3、指针变量只能指向定义时所规定类型的变量 4、指针变量定义后,变量值不确定,应用前必须先赋值,指针变量的

4、初始化 一般形式:存储类型 数据类型 *指针名=初始地址值;,赋给指针变量, 不是赋给目标变量,例 int i; int *p=,变量必须已说明过 类型应一致,例 int i; int *p=,用已初始化指针变量作初值,例 main( ) int i; static int *p= . (),不能用auto变量的地址 去初始化static型指针,例 main( ) int i=10; int *p; *p=i; printf(“%d”,*p); ,危险!,例 main( ) int i=10,k; int *p; p= ,指针变量必须先赋值,再使用.,零指针与空类型指针 零指针:(空指针) 定

5、义:指针变量值为零 表示: int * p=0;,p指向地址为0的单元, 系统保证该单元不作它用 表示指针变量值没有意义,#define NULL 0 int *p=NULL:,p=NULL与未对p赋值不同 用途: 避免指针变量的非法引用 在程序中常作为状态比较,例 int *p; . while(p!=NULL) . ,void *类型指针 表示: void *p; 使用时要进行强制类型转换,例 char *p1; void *p2; p1=(char *)p2; p2=(void *)p1;,表示不指定p是指向哪一种 类型数据的指针变量,指针变量是一种特殊的变量,变量中存放的不是某种数据类

6、型的数据,而是另一个变量或常量的地址。 指针运算符 取地址运算“ 则 p1= /*p2指针赋值*/ (2)指针变量运算: 指针变量:只有加或减的操作( +,-,+,-) 指针由当前所指向的位置向前或向后移动n个数据元素的位置。移动后的实际地址为:p n*sizeof(数据类型) (3)指针的关系运算 指向同种数据类型的指针可作关系运算,表示它们所存放的地址之间的关系。 可使用的运算符: , = = , !=,8.2.3 指针的运算,例 指针例题,main() int a; int *pa= ,运行结果: a:10 *pa:10 scanf(%d,%d, ,运行结果:a=5,b=9 max=9,

7、min=5,5,2006,9,2008,2006,2008,2006,8.3 .1 指针作为函数参数,swap(int x,int y) int temp; temp=x; x=y; y=temp; main() int a,b; scanf(%d,%d, ,例 将数从大到小输出值传递,5,9,5,5,9,COPY,值传递,运行结果:5, 9,8.3 指针与函数,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, ,5,9,200

8、0,2002,5,9,COPY,5,例 将数从大到小输出地址传递,共享内存,“双向”传递,地址传递,运行结果:9,5,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, ,运行结果:9,9,编译警告! 结果不对!,int x; int *p=,例 将数从大到小输出,5,9,2000,2002,9,9,COPY,假设2000,指针变量在使用前 必须赋值!,8.3.2 指针型函数(返回指针值的函数),作用:函数返回的值,不是数值

9、,而是地址 函数定义形式: 类型标识符 *函数名(参数表); 例 int *f(int x, int y),例 运用指针函数求两个数中的最大值,#include int *max(int *i,int *j) return (*i*j ? i:j); /*返回最大数的指针*/ void main() int a,b,*p; scanf(%d,%d, ,运行结果: 输入:12,2 max=12,8.3.3 函数指针 函数在编译时被分配的入口地址,用函数名表示,函数指针变量赋值:如p=max;,函数返回值的数据类型,专门存放函数入口地址 可指向返回值类型相同的不同函数,指向函数的指针变量(函数指针

10、) 定义形式: 数据类型 (*指针变量名)(); 如 int (*p)();,函数指针变量指向的函数必须有函数说明,函数调用形式: c=max(a,b); c=(*p)(a,b); c=p (a,b); 对函数指针变量pn, p+, p-无意义,( )不能省 int (*p)() 与 int *p()不同,例 用函数指针变量调用函数,比较两个数大小,main() int max(int ,int); int a,b,c; scanf(%d,%d, ,main() int max(int ,int), (*p)(); int a,b,c; p=max; scanf(%d,%d, ,用函数指针变量

11、作函数参数,例 用函数指针变量作参数,求最大值、最小值和两数之和,例 写一个函数,求两个int型变量中居于较大值的变量的地址,2,3,2002,2000,*,例 写一个函数,求两个int型变量中居于较大值的变量的地址,2002,例 写一个函数,求两个int型变量中居于较大值的变量的地址,2,3,3,2,*,例 写一个函数,求两个int型变量中居于较大值的变量的地址,不能返回形参或局部变量 的地址作函数返回值,200A,数组在内存中,每一个数组元素都有一个固定的地址,这个地址可以用指针变量来进行操作。 数组中指针的概念: 数组的指针数组在内存中的起始地址; 数组元素的指针数组元素在内存中的起始地

12、址 指向数组的指针变量的定义 int array10, *pointer=array; int array10, *pointer= 数组名代表数组在内存中的起始地址(即下标为0的元素的地址),所以可用数组名给指针变量赋值 数组元素的引用 既可用下标法,也可用指针法。使用下标法,直观;而使用指针法,能使目标程序占用内存少、运行速度快,8.4 指针与数组,8.4.1 指向数组元素的指针变量,例 int array10; int *p; p=,数组名是表示数组首地址的地址常量,指针在数组及其它的运算 指针变量的赋值运算 p= (指针变量p2值p1) 不能把一个整数p,也不能把p的值整型变量,如 i

13、nt i, *p; p=1000; () i=p; (),指针变量与其指向的变量具有相同数据类型,8.4.2 通过指针引用数组元素,指针的算术运算: pi p id (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指向int型数组,且p= 则p+1 指向a1,例 int a10; int *p=,例 int a10; int *p1=,1,指针变量的关系运算 若p1和p2指向同一数组,则 p1

14、p2 表示p1指的元素在后 p1=p2 表示p1与p2指向同一元素 若p1与p2不指向同一数组,比较无意义 p=NULL或p!=NULL,数组元素表示方法, 变址运算符 ai *(a+i),ai pi *(p+i) *(a+i),例 数组元素的引用方法,main() int a5,*pa,i; for(i=0;i5;i+) ai=i+1; pa=a; for(i=0;i5;i+) printf(*(pa+%d):%dn,i,*(pa+i); for(i=0;i5;i+) printf(*(a+%d):%dn,i,*(a+i); for(i=0;i5;i+) printf(pa%d:%dn,i,

15、pai); for(i=0;i5;i+) printf(a%d:%dn,i,ai); ,例 int a=1,2,3,4,5,6,7,8,9,10,*p=a,i; 数组元素地址的正确表示:(A) int y,*p= ,输出:5 6,例 注意指针变量的运算,6,main() int i,*p,a7; p=a; for(i=0;i7;i+) scanf(%d,p+); printf(n); for(i=0;i7;i+,p+) printf(%d,*p); ,例 注意指针的当前值,p=a;,指针变量可以指到数组后的内存单元,数组名作函数参数 数组名作函数参数,是地址传递 数组名作函数参数,实参与形参的对应关系,例 将数组a中的n个整数按相反顺序存放,实参与形参均用数组,void inv(int x, int n) int t,i,j,m=(n-1)/2; for(i=0;i=m;i+) j=n-1-i; t=xi; xi=xj; xj=t; main() int i,a10=3,7,9,11,0,6,7,5,4,2; inv(a,10); printf(The array has been reverted:n); for(i=0;i10;i+) printf(%d,ai); printf(n); ,m=4,例 将数组a

展开阅读全文
相关资源
正为您匹配相似的精品文档
相关搜索

最新文档


当前位置:首页 > 中学教育 > 教学课件 > 高中课件

电脑版 |金锄头文库版权所有
经营许可证:蜀ICP备13022795号 | 川公网安备 51140202000112号