C语言程序设计辅导.ppt
![资源得分’ title=](/images/score_1.gif)
![资源得分’ title=](/images/score_1.gif)
![资源得分’ title=](/images/score_1.gif)
![资源得分’ title=](/images/score_1.gif)
![资源得分’ title=](/images/score_05.gif)
《C语言程序设计辅导.ppt》由会员分享,可在线阅读,更多相关《C语言程序设计辅导.ppt(50页珍藏版)》请在淘文阁 - 分享文档赚钱的网站上搜索。
1、C C语言程序设计语言程序设计第八讲第八讲一、对一、对 C语言的深入讨论语言的深入讨论1、对函数的讨论、对函数的讨论函数的参数函数的参数函数的递归调用函数的递归调用2、标识符的作用域、标识符的作用域3、函数的存储分类、函数的存储分类4、编译预处理、编译预处理5、动态存储分配、动态存储分配1命令行参数命令行参数命令行:在操作系统状态下,为执行某个程序而键入命令行:在操作系统状态下,为执行某个程序而键入的一行字符的一行字符命令行一般形式:命令行一般形式:命令名命令名 参数参数1 参数参数2参数参数nmain(int argc,char *argv)命令行参数传递带参数的带参数的main函数形式:函
2、数形式:C:TC copy.exe source.c temp.c有3个字符串参数的命令行命令行中参数个数元素指向命令行参数中各字符串首地址形参名任意命令行实参main(形参)系统自动调用main函数时传递第一个参数: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
3、.在DOS状态下运行(test.exe所在路径下)例如:C:TC test.exe hello world!运行结果:hello world!运行结果:test hello world!argv0argv1argv2char*argvworldtesthelloargvargc=3函数的递归调用3个条件个条件:(1)问题转化)问题转化(2)利用转化过程解决问题)利用转化过程解决问题(3)必须有明确的结束条件)必须有明确的结束条件例例:fun(int x)if(x/20)fun(x/2);printf(“%d”,x);Main()fun(6);2 变量的存储属性变量的存储属性概述概述变量是对程序
4、中数据的存储空间的抽象变量是对程序中数据的存储空间的抽象内存.main()int a;a=10;printf(“%d”,a);编译或函数调用时为其分配内存单元1020002001程序中使用变量名对内存操作变量的属性变量的属性数据类型:变量所持有的数据的性质(数据类型:变量所持有的数据的性质(操作属性操作属性)存储属性存储属性存储器类型:寄存器、静态存储区、动态存储区存储器类型:寄存器、静态存储区、动态存储区生存期生存期:变量在某一时刻存在:变量在某一时刻存在-静态变量与动态静态变量与动态变量变量作用域作用域:变量在某区域内有效:变量在某区域内有效-局部变量与全局局部变量与全局变量变量变量的存储
5、类型变量的存储类型auto -自动型自动型register-寄存器型寄存器型static -静态型静态型extern -外部型外部型变量定义格式变量定义格式:存储类型存储类型 数据类型数据类型 变量表变量表;2.1 变量的存储属性变量的存储属性概述概述变量是对程序中数据的存储空间的抽象变量是对程序中数据的存储空间的抽象如:int sum;auto int a,b,c;register int i;static float x,y;局部变量与全局变量局部变量与全局变量局部变量局部变量-内部变量内部变量定义:在定义:在函数内定义函数内定义,只在本函数内有效只在本函数内有效说明:说明:main中定义
6、的变量只在中定义的变量只在main中有效中有效不同函数中同名变量,占不同内存单元不同函数中同名变量,占不同内存单元形参属于局部变量形参属于局部变量可定义在复合语句中有效的变量可定义在复合语句中有效的变量局部变量可用存储类型局部变量可用存储类型:auto register static (默认为默认为auto)全局变量全局变量-外部变量外部变量定义:在定义:在函数外定义函数外定义,可为,可为本文件所有函数共用本文件所有函数共用有效范围:从有效范围:从定义变量的位置开始定义变量的位置开始到本源文件结束,及有到本源文件结束,及有extern说明说明的其它源文件的其它源文件 应尽量少使用全局变量,因为
7、:Y全局变量在程序全部执行过程中占用存储单元Y降低了函数的通用性、可靠性,可移植性Y降低程序清晰性,容易出错 定义 说明u次数:只能1次 可说明多次u位置:所有函数之外 函数内或函数外u分配内存:分配内存,可初始化 不分配内存,不可初始化外部变量说明:外部变量说明:extern 数据类型数据类型 变量表;变量表;外部变量定义与外部变量说明不同外部变量定义与外部变量说明不同若外部变量与局部变量同名,则外部变量被屏蔽若外部变量与局部变量同名,则外部变量被屏蔽外部变量可用存储类型外部变量可用存储类型:缺省缺省 或或 staticint sum;int fun1()sum+=20;int a;int
8、fun2()a=20;sum+=a;main()sum=0;fun1();a=8;fun2();printf(“sum=%d a=%d”,sum,a);40)在一个C 源程序文件中所定义的全局变量,其作用域为()。A)所在文件的全部范围B)所在程序的全部范围C)所在函数的全部范围D)由具体定义位置和extern 说明来决定范围例 外部变量定义与说明int max(int x,int y)int z;z=xy?x:y;return(z);main()extern int a,b;printf(max=%d,max(a,b);int a=13,b=-8;运行结果:max=13extern int
9、a,b;int max()int z;z=ab?a:b;return(z);main()printf(max=%d,max();int a=13,b=-8;int a=3,b=5;max(int a,int b)int c;c=ab?a:b;return(c);main()int a=8;printf(max=%d,max(a,b);例 外部变量与局部变量运行结果:max=8动态变量与静态变量动态变量与静态变量存储方式存储方式静态存储:程序运行期间分配固定存储空间静态存储:程序运行期间分配固定存储空间动态存储:程序运行期间根据需要动态分配存储空间动态存储:程序运行期间根据需要动态分配存储空间内
10、存用户区内存用户区程序区静态存储区动态存储区全局变量、局部静态变量形参变量局部动态变量(auto register)函数调用现场保护和返回地址等生存期静态变量:从程序开始执行到程序结束动态变量:从包含该变量定义的函数开始执行至函数执行结束变量存储类型静态动态存储方式程序整个运行期间函数调用开始至结束生存期编译时赋初值,只赋一次每次函数调用时赋初值自动赋初值0或空字符不确定未赋初值静态存储区动态区存储区寄存器局部变量外部变量作用域定义变量的函数或复合语句内本文件其它文件u局部变量默认为auto型uregister型变量个数受限,且不能为long,double,float型u局部static变量具
11、有全局寿命和局部可见性u局部static变量具有可继承性uextern不是变量定义,可扩展外部变量作用域register局部staticauto外部static外部存储类别例 文件file1.cint a;main().f2;.f1;.f1()auto int b;f2;.f2()static int c;C作用域b作用域a作用域mainf2f1mainf1f2maina生存期:b生存期:c生存期:例 auto 变量的作用域main()int x=1;void prt(void);int x=3;prt();printf(“2nd x=%dn”,x);printf(“1st x=%dn”,x)
12、;void prt(void)int x=5;printf(“3th x=%dn”,x);运行结果:3th x=52nd x=31st x=1x=1作用域x=1作用域x=3作用域x=5作用域main()void increment(void);increment();increment();increment();void increment(void)int x=0;x+;printf(“%dn”,x);例 局部静态变量值具有可继承性运行结果:1 1 1main()void increment(void);increment();increment();increment();void in
13、crement(void)static int x=0;x+;printf(“%dn”,x);运行结果:1 2 3例 引用其它文件中的外部变量int global;extern float x;main()int local;.extern int global;static int number;func2().float x;static int number;func3()extern int global;.file1.cfile2.cfile3.c4 编译预处理作用:对源程序编译之前做一些处理,生成扩展C源程序种类宏定义#define文件包含#include条件编译#if-#else
14、-#endif等格式:“#”开头占单独书写行语句尾不加分号如 if(x=YES)printf(“correct!n”);else if(x=NO)printf(“error!n”);展开后:if(x=1)printf(“correct!n”);else if(x=0)printf(“error!n”);4.1 宏定义不带参数宏定义一般形式:#define 宏名 宏体功能:用指定标识符(宏名)代替字符序列(宏体)宏展开:预编译时,用宏体替换宏名-不作语法检查如#define YES 1#define NO 0#define PI 3.1415926#define OUT printf(“Hell
15、o,World”);宏体可缺省,表示宏名定义过或取消宏体定义位置:任意(一般在函数外面)作用域:从定义命令到文件结束#undef可终止宏名作用域 格式:#undef 宏名例#define YES 1 main().#undef YES#define YES 0 max().YES原作用域YES新作用域宏定义可嵌套,不能递归例#define MAX MAX+10 ()引号中的内容与宏名相同也不置换例#define PI 3.14159 printf(“2*PI=%fn”,PI*2);宏展开:printf(“2*PI=%fn”,3.14159*2);宏定义中使用必要的括号()例#define WI
16、DTH 80#define LENGTH WIDTH+40 var=LENGTH*2;宏展开:var=80+40*2;()()例#define WIDTH 80#define LENGTH WIDTH+40 var=LENGTH*2;宏展开:var=80+40*2;带参数宏定义一般形式:#define 宏名(参数表)宏体例#define S (r)PI*r*r相当于定义了不带参宏S,代表字符串“(r)PI*r*r”宏展开:形参用实参换,其它字符保留宏体及各形参外一般应加括号()例#define S(a,b)a*b .area=S(3,2);宏展开:area=3*2;不能加空格例#define
17、POWER(x)x*x x=4;y=6;z=POWER(x+y);宏展开:z=x+y*x+y;一般写成:#define POWER(x)(x)*(x)宏展开:z=(x+y)*(x+y);#define MAX(x,y)(x)(y)?(x):(y).main()int a,b,c,d,t;.t=MAX(a+b,c+d);宏展开:t=(a+b)(c+d)?(a+b):(c+d);int max(int x,int y)return(xy?x:y);main()int a,b,c,d,t;.t=max(a+b,c+d);例 用宏定义和函数实现同样的功能带参的宏与函数区别带参宏函数处理过程不分配内存简
18、单的字符置换分配内存先求实参值,再代入形参处理时间编译时程序运行时参数类型无类型问题定义实参,形参类型程序长度变长不变运行速度不占运行时间调用和返回占时间08/9 26以下关于宏的叙述中正确的是以下关于宏的叙述中正确的是()A)宏名必须用大写字母表示)宏名必须用大写字母表示B)宏定义必须位于源程序中所有语句之前宏定义必须位于源程序中所有语句之前C)宏替换没有数据类型限制宏替换没有数据类型限制D)宏调用比函数调用耗费时间)宏调用比函数调用耗费时间08/4(28)以下叙述中错误的是(以下叙述中错误的是()。)。A)在程序中凡是以)在程序中凡是以“#”开始的语句行都是预处理命令行开始的语句行都是预处
19、理命令行B)预处理命令行的最后不能以分号表示结束)预处理命令行的最后不能以分号表示结束C)#define MAX 是合法的宏定义命令行是合法的宏定义命令行D)C 程序对预处理命令行的处理是在程序执行的过程中进行的程序对预处理命令行的处理是在程序执行的过程中进行的43)若程序中有宏定义行:#define N 100,则下列叙述中正确的是()。A)宏定义行中定义了标识符N 的值为整数100B)在编译程序对C 源程序进行预处理时用100 替换标识符NC)对C 源程序进行编译时用100 替换标识符ND)在运行时用100 替换标识符N4.2 文件包含功能:一个源文件可将另一个源文件的内容全部包含进来一般
20、形式:#include “文件名”或#include#include “file2.c”file1.cfile2.cfile1.cfile2.cABA处理过程:预编译时,用被包含文件的内容取代该预处理命令,再对“包含”后的文件作一个源文件编译 直接按标准目录搜索“”先在当前目录搜索,再搜索标准目录可指定路径被包含文件内容源文件(*.c)头文件(*.h)宏定义数据结构定义函数说明等文件包含可嵌套#include “file2.c”file1.cAfile3.cC#include “file3.c”file2.c Bfile1.cAfile3.cfile2.c 动态存储链表的特点链表是一种动态的进
21、行存储分配的数据结构,程序执行中,可以在需要时开辟存储单元,在不需要时释放存储单元。链表的结点包含数据域和链接域,数据域用来保存数据信息,链接域用来保存该结点的后继结点或前驱结点的地址。一个链表用一个头指针来保存该链表的首地址,即第一个结点的地址。头指针是一个链表的标志。一个单链表的逻辑示意图 创建链表 相关函数:malloc函数1.原型:void*malloc(unsigned int size);2.功能:在内存的动态存储区中分配size个字节的连续空间,它的返回值是所分配的那一段空间的起始地址,若分配失败,则返回一个空指针(0)。calloc函数1.原型:void*calloc(unsi
22、gned int n,unsigned int size);2.功能:内存的动态存储区中分配n个长度为size个字节的连续空间,它的返回值是指向所分配空间的起始地址,若分配失败,则返回一个空指针(0)。free函数1.原型:void free(void*p);2.功能:释放p所指向的内存区,该函数没有返回值。一般p是调用malloc函数或calloc函数的返回值。第十三章 结构体与共用体13.1 结构体&结构体是一种构造数据类型&用途:把不同类型的数据组合成一个整体-自定义数据类型结构体类型定义struct 结构体名 类型标识符 成员名;类型标识符 成员名;.;成员类型可以是基本型或构造型st
- 配套讲稿:
如PPT文件的首页显示word图标,表示该PPT已包含配套word讲稿。双击word图标可打开word文档。
- 特殊限制:
部分文档作品中含有的国旗、国徽等图片,仅作为作品整体效果示例展示,禁止商用。设计者仅对作品中独创性部分享有著作权。
- 关 键 词:
- 语言程序设计 辅导
![提示](https://www.taowenge.com/images/bang_tan.gif)
限制150内