资源目录
压缩包内文档预览:
编号:21836451
类型:共享资源
大小:13.43MB
格式:ZIP
上传时间:2019-09-06
上传人:QQ24****1780
认证信息
个人认证
王**(实名认证)
浙江
IP属地:浙江
25
积分
- 关 键 词:
-
大学
语言程序设计
任正云
课件
ppt
- 资源描述:
-
大学C语言程序设计-任正云-课件PPT,大学,语言程序设计,任正云,课件,ppt
- 内容简介:
-
第十章 指针C程序设计中使用指针可以:使程序简洁、紧凑、高效有效地表示复杂的数据结构动态分配内存得到多于一个的函数返回值8.1 地址和指针变量与地址程序中: int i; float k; 内存中每个字节有一个编号-地址ik 编译或函数调用时为其分配内存单元变量是对程序中数据存储空间的抽象指针与指针变量指针:一个变量的地址指针变量:专门存放变量地址的变量叫2000指针指针变量 变量的内容 变量的地址&与*运算符含义含义: 取变量的地址单目运算符结合性:自右向左含义: 取指针所指向变量的内容单目运算符结合性:自右向左两者关系:互为逆运算理解i_pointer-指针变量,它的内容是地址量*i_pointer-指针的目标变量,它的内容是数据&i_pointer-指针变量占用内存的地址i_pointer &i &(*i_pointer)i *i_pointer *(&i)i_pointer = &i = &(*i_pointer)i = *i_pointer = *(&i)直接访问与间接访问直接访问:按变量地址存取变量值间接访问:通过存放变量地址的变量去访问变量例 i=3; -直接访问3例 *i_pointer=20; -间接访问20例 k=i; -直接访问 k=*i_pointer; -间接访问10例 k=i; k=*i_pointer; 8.2 指针变量指针变量与其所指向的变量之间的关系指针变量的定义一般形式: 存储类型 数据类型 *指针名;合法标识符指针变量本身的存储类型指针的目标变量的数据类型表示定义指针变量不是*运算符例 int *p1,*p2; float *q ; static char *name;注意:1、int *p1, *p2; 与 int *p1, p2;2、指针变量名是p1,p2 ,不是*p1,*p23、指针变量只能指向定义时所规定类型的变量4、指针变量定义后,变量值不确定,应用前必须先赋值指针变量的初始化一般形式:存储类型 数据类型 *指针名=初始地址值;赋给指针变量,不是赋给目标变量例 int i; int *p=&i;例 int i; int *p=&i; int *q=p;用已初始化指针变量作初值例 main( ) int i; static int *p=&i; . ()不能用auto变量的地址去初始化static型指针例 main( ) int i=10; int *p; *p=i; printf(%d,*p); 危险!例 main( ) int i=10,k; int *p; p=&k; *p=i; printf(%d,*p); 指针变量必须先赋值,再使用零指针与空类型指针零指针:(空指针)定义:指针变量值为零表示: int * p=0; p指向地址为0的单元,系统保证该单元不作它用表示指针变量值没有意义#define NULL 0int *p=NULL:p=NULL与未对p赋值不同用途: 避免指针变量的非法引用在程序中常作为状态比较 例 int *p; . while(p!=NULL) . void *类型指针表示: void *p; 使用时要进行强制类型转换例 char *p1; void *p2; p1=(char *)p2; p2=(void *)p1;表示不指定p是指向哪一种类型数据的指针变量例 指针的概念main() int a; int *pa=&a; a=10; printf(a:%dn,a); printf(*pa:%dn,*pa); printf(&a:%x(hex)n,&a); printf(pa:%x(hex)n,pa); printf(&pa:%x(hex)n,&pa);运行结果:a:10*pa:10&a:f86(hex)pa:f86(hex)&pa:f88(hex)例 输入两个数,并使其从大到小输出main() int *p1,*p2,*p,a,b; scanf(%d,%d,&a,&b); p1=&a; p2=&b; if(ab) p=p1; p1=p2; p2=p; printf(a=%d,b=%dn,a,b); printf(max=%d,min=%dn,*p1,*p2);运行结果:a=5,b=9 max=9,min=552006920082006200820068.3 指针变量作为函数参数地址传递特点:共享内存,“双向”传递swap(int x,int y) int temp; temp=x; x=y; y=temp;main() int a,b; scanf(%d,%d,&a,&b); if(ab) swap(a,b); printf(n%d,%dn,a,b);例 将数从大到小输出59559COPYswap(int x,int y) int temp; temp=x; x=y; y=temp;main() int a,b; scanf(%d,%d,&a,&b); if(ab) swap(a,b); printf(n%d,%dn,a,b);例 将数从大到小输出值传递59运行结果:5, 98.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,&a,&b); pointer_1=&a; pointer_2=&b; if(ab)swap(pointer_1,pointer_2); printf(n%d,%dn,a,b);592000200259COPY5例 将数从大到小输出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,%dn,a,b);592000200259例 将数从大到小输出运行结果: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,&a,&b); pointer_1=&a; pointer_2=&b; if(ab) swap(pointer_1,pointer_2); printf(n%d,%dn,a,b);运行结果:9,9编译警告!结果不对!int x;int *p=&x;x;例 将数从大到小输出592000200299COPY假设2000指针变量在使用前必须赋值!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,%dn,a,b);运行结果:5,9例 将数从大到小输出值传递5920002002COPY559运行结果:5,9例 将数从大到小输出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(%d,%d,*pointer_1,*pointer_2);5920002002COPY2000地址传递200020028.4 指针与数组指向数组元素的指针变量例 int array10; int *p; p=&array0; / p=array;数组名是表示数组首地址的地址常量指针的运算指针变量的赋值运算p=&a; (将变量a地址p)p=array; (将数组array首地址p)p=&arrayi; (将数组元素地址p)p1=p2; (指针变量p2值p1)不能把一个整数p,也不能把p的值整型变量如 int i, *p; p=1000; () i=p; ()指针变量与其指向的变量具有相同数据类型指针的算术运算:pi p id (i为整型数,d为p指向的变量所占字节数)p+, p-, p+i, p-i, p+=i, p-=i等若p1与p2指向同一数组,p1-p2=两指针间元素个数(p1-p2)/dp1+p2 无意义例 p指向float数,则 p+1 p+1 4例 p指向int型数组,且p=&a0; 则p+1 指向a1例 int a10; int *p=&a2; p+; *p=1;例 int a10; int *p1=&a2; int *p2=&a5; 则:p2-p1=3;1指针变量的关系运算若p1和p2指向同一数组,则p1p2 表示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,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)&(a+1) (B)a+ (C)&p (D)&pi数组名是地址常量p+,p- ()a+,a- ()a+1, *(a+2) ()例 void main() int a =5,8,7,6,2,7,3; int y,*p=&a1; y=(*-p)+; printf(%d ,y); printf(%d,a0); 输出:5 6例 注意指针变量的运算6main() 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中的n个整数按相反顺序存放 void inv(int *x, int n) int t,*p,*i,*j,m=(n-1)/2; i=x; j=x+n-1; p=x+m; for(;i=p;i+,j-) t=*i; *i=*j; *j=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);实参用数组,形参用指针变量例 将数组a中的n个整数按相反顺序存放 void inv(int *x, int n) int t,*i,*j,*p,m=(n-1)/2; i=x; j=x+n-1; p=x+m; for(;i=p;i+,j-) t=*i; *i=*j; *j=t; main() int i,a10,*p=a; for(i=0;i10;i+,p+) scanf(%d,p); p=a; inv(p,10); printf(The array has been reverted:n); for(p=a;pa+10;p+) printf(%d,*p);实参与形参均用指针变量例 将数组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,*p=a; for(i=0;i10;i+,p+) scanf(%d,p); p=a; inv(p,10); printf(The array has been reverted:n); for(p=arr;parr+10;p+) printf(%d ,*p);实参用指针变量,形参用数组一级指针变量与一维数组的关系int *p 与 int q10 数组名是指针(地址)常量p=q; p+i 是qi的地址数组元素的表示方法:下标法和指针法, 即若p=q, 则 pi qi *(p+i) *(q+i) 形参数组实质上是指针变量,即int q int *q在定义指针变量(不是形参)时,不能把int *p 写成int p;系统只给p分配能保存一个指针值的内存区(一般2字节);而给q分配2*10字节的内存区8.6 用指针访问字符串字符串表示形式用字符数组实现例 main( ) char string=I love China! ; printf(%sn,string); printf(%sn,string+7); 用字符指针实现例 main( ) char *string=“I love China!”; printf(“%sn”,string); string+=7; while(*string) putchar(string0); string+; 字符指针初始化:把字符串首地址赋给string char *string; string=“I love China!”;*string!=0字符串指针作函数参数例 用函数调用实现字符串复制(1)用字符数组作参数(2)用字符指针变量作参数void copy_string(char from,char to) int i=0; while(fromi!=0) toi=fromi;i+; toi=0;main() char a=I am a teacher.; char b=You are a student.; printf(string_a=%sn string_b=%sn,a,b); copy_string(a,b); printf(nstring_a=%snstring_b=%sn,a,b);void copy_string(char *from,char *to) for(;*from!=0;from+,to+) *to=*from; *to=0;main() char *a=I am a teacher.; char *b=You are a student.; printf(string_a=%snstring_b=%sn,a,b); copy_string(a,b); printf(nstring_a=%snstring_b=%sn,a,b);字符指针变量与字符数组char *cp; 与 char str20;str由若干元素组成,每个元素放一个字符;而cp中存放字符串首地址 char str20; str=“I love China!”; () char *cp; cp=“I love China!”; ()str是地址常量;cp是地址变量cp接受键入字符串时,必须先开辟存储空间例 char str10; scanf(“%s”,str); ()而 char *cp; scanf(%s, cp); ()改为: char *cp,str10; cp=str; scanf(%s,cp); ()字符串与数组关系字符串用一维字符数组存放字符数组具有一维数组的所有特点数组名是指向数组首地址的地址常量数组元素的引用方法可用指针法和下标法数组名作函数参数是地址传递等区别存储格式:字符串结束标志赋值方式与初始化输入输出方式:%s %cchar str=Hello! ; ()char str=Hello! ; ()char str=H, e, l, l, o, ! ; ()char *cp=Hello; ()int a=1,2,3,4,5; ()int *p=1,2,3,4,5; ()char str10,*cp;int a10,*p;str=Hello; ()cp=Hello! ; ()a=1,2,3,4,5; ()p=1,2,3,4,5; ()scanf(“%s”,str);printf(“%s”,str);gets(str);puts(str);8.7 指针数组和多级指针用于处理二维数组或多个字符串指针数组定义:数组中的元素为指针变量定义形式:存储类型 数据类型 *数组名数组长度说明;例 int *p4;指针所指向变量的数据类型指针本身的存储类型指针数组赋值与初始化指针数组赋值与初始化 char name59=gain, much, stronger, point, bye; char *name5=gain, much, stronger, point, bye;二维数组与指针数组区别:二维数组存储空间固定字符指针数组相当于可变列长的二维数组分配内存单元=数组维数*2+各字符串长度指针数组元素的作用相当于二维数组的行名但指针数组中元素是指针变量二维数组的行名是地址常量main() int b23,*pb2; int i,j; for(i=0;i2;i+) for(j=0;j3;j+) bij=(i+1)*(j+1); pb0=b0; pb1=b1; for(i=0;i2;i+) for(j=0;j3;j+,pbi+) printf(b%d%d:%2dn,i,j,*pbi);例 用指针数组处理二维数组例 对字符串排序(简单选择排序)main() void sort(char *name,int n), print(char *name,int n); char *name=Follow me,BASIC, Great Wall,FORTRAN,Computer ; int n=5; sort(name,n); print(name,n);void sort(char *name,int n) char *temp; int i,j,k; for(i=0;in-1;i+) k=i; for(j=i+1;j0) k=j; if(k!=i) temp=namei; namei=namek; namek=temp; i=0例 对字符串排序(简单选择排序)main() void sort(char *name,int n), print(char *name,int n); char *name=Follow me,BASIC, Great Wall,FORTRAN,Computer ; int n=5; sort(name,n); print(name,n);void sort(char *name,int n) char *temp; int i,j,k; for(i=0;in-1;i+) k=i; for(j=i+1;j0) k=j; if(k!=i) temp=namei; namei=namek; namek=temp; name0name1name2name3name4nameGreat WallFORTRANComputerFollow meBASICi=1例 对字符串排序(简单选择排序)main() void sort(char *name,int n), print(char *name,int n); char *name=Follow me,BASIC, Great Wall,FORTRAN,Computer ; int n=5; sort(name,n); print(name,n);void sort(char *name,int n) char *temp; int i,j,k; for(i=0;in-1;i+) k=i; for(j=i+1;j0) k=j; if(k!=i) temp=namei; namei=namek; namek=temp; name0name1name2name3name4nameGreat WallFORTRANComputerFollow meBASICi=2例 对字符串排序(简单选择排序)main() void sort(char *name,int n), print(char *name,int n); char *name=Follow me,BASIC, Great Wall,FORTRAN,Computer ; int n=5; sort(name,n); print(name,n);void sort(char *name,int n) char *temp; int i,j,k; for(i=0;in-1;i+) k=i; for(j=i+1;j0) k=j; if(k!=i) temp=namei; namei=namek; namek=temp; name0name1name2name3name4nameGreat WallFORTRANComputerFollow meBASICi=3例 对字符串排序(简单选择排序)main() void sort(char *name,int n), print(char *name,int n); char *name=Follow me,BASIC, Great Wall,FORTRAN,Computer ; int n=5; sort(name,n); print(name,n);void sort(char *name,int n) char *temp; int i,j,k; for(i=0;in-1;i+) k=i; for(j=i+1;j0) k=j; if(k!=i) temp=namei; namei=namek; namek=temp; name0name1name2name3name4nameGreat WallFORTRANComputerFollow meBASIC指向指针的指针定义: 指向指针的指针一级指针:指针变量中存放目标变量的地址例 int *p1; int *p2; int i=3; p2=&i; p1=&p2; *p1=5;二级指针:指针变量中存放一级指针变量的地址例 int *p; int i=3; p=&i; *p=5;一级指针单级间接寻址二级指针一级指针目标变量二级间接寻址定义形式:存储类型 数据类型 *指针名;如 char *p;例 int i, *p; p=&i; ()/p是二级指针,不能用变量地址为其赋值指针本身的存储类型最终目标变量的数据类型*p是p间接指向对象的地址*p是p间接指向对象的值例 int i=3; int *p1; int *p2; p1=&i; p2=&p1; *p=5;多级指针例 三级指针 int *p; 四级指针 char *p;例 一级指针与二级指针#include void swap(int *r,int *s) int *t; t=r; r=s; s=t;main() int a=1,b=2,*p,*q; p=&a; q=&b; swap(p,q); printf(%d,%dn,*p,*q);200020022000例 一级指针与二级指针#include void swap(int *r,int *s) int *t; t=r; r=s; s=t;main() int a=1,b=2,*p,*q; p=&a; q=&b; swap(p,q); printf(%d,%dn,*p,*q);输出: 1,2例 一级指针与二级指针#include void swap(int *r,int *s) int *t; t=r; r=s; s=t;main() int a=1,b=2,*p,*q; p=&a; q=&b; swap(p,q); printf(%d,%dn,*p,*q);输出: 1,2例 一级指针与二级指针#include void swap(int *r,int *s) int *t; t=*r; *r=*s; *s=t;main() int a=1,b=2,*p,*q; p=&a; q=&b; swap(&p,&q); printf(%d,%dn,*p,*q);200020022000例 一级指针与二级指针#include void swap(int *r,int *s) int *t; t=*r; *r=*s; *s=t;main() int a=1,b=2,*p,*q; p=&a; q=&b; swap(&p,&q); printf(%d,%dn,*p,*q);20002002输出: 2,1例 一级指针与二级指针#include void swap(int *r,int *s) int *t; t=*r; *r=*s; *s=t;main() int a=1,b=2,*p,*q; p=&a; q=&b; swap(&p,&q); printf(%d,%dn,*p,*q);输出: 2,1例 用二级指针处理字符串#define NULL 0void main() char *p; char *name=hello,good,world,bye,; p=name+1; printf(%o : %s , *p,*p); p+=2; while(*p!=NULL) printf(%sn,*p+);运行结果:644 : good bye用*p可输出地址(%o或%x), 也可用它输出字符串(%s)*(p+)带形参的main函数命令行:在操作系统状态下,为执行某个程序而键入的一行字符命令行一般形式:命令名 参数1 参数2参数nmain(int argc, char *argv) 命令行参数传递带参数的main函数形式:C:TC copy.exe source.c temp.c有3个字符串参数的命令行命令行中参数个数元素指向命令行参数中各字符串首地址形参名任意第一个参数: main所在的可执行文件名例 输出命令行参数/*test.c*/main(int argc, char *argv) while(argc1) +argv; printf(%sn,*argv); -argc; main(int argc, char *argv) while(argc-0) printf(%sn,*argv+);1. 编译、链接test.c,生成可执行文件test.exe2. 在DOS状态下运行(test.exe所在路径下)例如: C:TC test.exe hello world!运行结果:hello world!运行结果:test hello world!8.8 指向函数的指针函数指针:函数在编译时被分配的入口地址,用函数名表示函数指针变量赋值:如p=max;函数返回值的数据类型专门存放函数入口地址可指向返回值类型相同的不同函数指向函数的指针变量定义形式: 数据类型 (*指针变量名)(); 如 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,&a,&b); c=max(a,b); printf(a=%d,b=%d,max=%dn,a,b,c); int max(int x,int y) int z; if(xy) z=x; else z=y; return(z);main() int max(int ,int),
- 温馨提示:
1: 本站所有资源如无特殊说明,都需要本地电脑安装OFFICE2007和PDF阅读器。图纸软件为CAD,CAXA,PROE,UG,SolidWorks等.压缩文件请下载最新的WinRAR软件解压。
2: 本站的文档不包含任何第三方提供的附件图纸等,如果需要附件,请联系上传者。文件的所有权益归上传用户所有。
3.本站RAR压缩包中若带图纸,网页内容里面会有图纸预览,若没有图纸预览就没有图纸。
4. 未经权益所有人同意不得将文件中的内容挪作商业或盈利用途。
5. 人人文库网仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对用户上传分享的文档内容本身不做任何修改或编辑,并不能对任何下载内容负责。
6. 下载文件中如有侵权或不适当内容,请与我们联系,我们立即纠正。
7. 本站不保证下载资源的准确性、安全性和完整性, 同时也不承担用户因使用这些下载资源对自己和他人造成任何形式的伤害或损失。

人人文库网所有资源均是用户自行上传分享,仅供网友学习交流,未经上传用户书面授权,请勿作他用。