C语言看不懂形参实参以及调用方法的必看实用教案

上传人:m**** 文档编号:568541535 上传时间:2024-07-25 格式:PPT 页数:62 大小:887.50KB
返回 下载 相关 举报
C语言看不懂形参实参以及调用方法的必看实用教案_第1页
第1页 / 共62页
C语言看不懂形参实参以及调用方法的必看实用教案_第2页
第2页 / 共62页
C语言看不懂形参实参以及调用方法的必看实用教案_第3页
第3页 / 共62页
C语言看不懂形参实参以及调用方法的必看实用教案_第4页
第4页 / 共62页
C语言看不懂形参实参以及调用方法的必看实用教案_第5页
第5页 / 共62页
点击查看更多>>
资源描述

《C语言看不懂形参实参以及调用方法的必看实用教案》由会员分享,可在线阅读,更多相关《C语言看不懂形参实参以及调用方法的必看实用教案(62页珍藏版)》请在金锄头文库上搜索。

1、主要内容:主要内容:1 1、函数的定义、函数的定义2 2、函数的调用(包括、函数的调用(包括(boku)(boku)嵌套调用和递嵌套调用和递归调用)归调用)4 4、局部变量和全局变量、局部变量和全局变量5 5、变量的存储类别、变量的存储类别 重点重点: :1)1)如何定义函数(即如何编写函数)如何定义函数(即如何编写函数)2)2)如何调用函数(包括如何调用函数(包括(boku)(boku)库函数和自库函数和自定义函数)定义函数) 第1页/共61页第一页,共62页。函数(hnsh)的引入函数:函数是完成某些特定(tdng)功能的代码块。使用函数的优点:1)实现模块化设计:将一个大任务分解成一个个

2、的小任务,然后每个任务分别用函数实现。2)实现“编写一次,多次调用”,避免在不同的程序中重复编写相同的函数。3)便于程序调试和维护,因为每个函数之间是相互独立的。函数的分类:库函数和用户自定义函数第2页/共61页第二页,共62页。8.1函数(hnsh)的定义例8.1编写函数max:求两个(lin)整数x和y中的较大数。intmax(intx,inty)/*函数头*/intz=x;/*函数体*/if(xb?a:b);或intmax(a,b)inta,b;/*形参的类型在函数体前、函数名后说明*/return(ab?a:b);前者为标准格式,后者为传统格式,通常用前者。第6页/共61页第六页,共6

3、2页。4.函数体:即函数功能的具体实现。它包括两部分:说明部分和执行部分,其中说明部分包括函数中所用的局部变量等的说明、函数中要调用的函数的说明。注意:函数不能嵌套定义,即函数内不能再定义函数,这样可以保证函数间是相互独立的,以实现模块化程序设计。5.空函数:函数类型函数名()调用此函数时,什么也不做。只是表明这里要调用一个(y)函数,而现在这个函数的功能还没实现。第7页/共61页第七页,共62页。空函数(hnsh)在程序设计中常常用到的:1)预留函数(hnsh),便于以后扩充程序功能。2)便于程序的模块化设计和调试:程序设计中往往根据需要确定若干模块,分别由一些函数(hnsh)来实现。一个大

4、系统,需要编写很多用户函数(hnsh),而这些函数(hnsh)不可能也没有必要同步完成,通常足从一些基本模块开始,编写一个调试一个,对于没有编写的函数(hnsh)就需要用空函数(hnsh)代替。从而也有利于集体创作。第8页/共61页第八页,共62页。空函数(hnsh)举例例8.3编写小学生算术练习系统(xtng)的主程序:显示主菜单,用户选择,根据选择执行加、减、乘、除、退出5项功能之一。重复上述步骤,直至选择退出。其中主程序调用的函数有:显示主菜单函数list_menu(),加、减、乘、除、退出函数分别是add(),sub(),mul(),divide(),end().以上函数除list_m

5、enu()外此时均为空函数。程序:l8_1_4.c第9页/共61页第九页,共62页。#includestdio.h/*l8_1_4.c*/main()voidadd(),sub(),mul(),divide(),end(),list_menu();intn;dolist_menu();scanf(%d,&n);getchar();switch(n)case1:add();break;case2:sub();break;case3:mul();break;case4:divide();break;case5:end();break;default:printf(nentererror,pleas

6、eagain.);while(n!=5);第10页/共61页第十页,共62页。voidlist_menu()printf(n*theexercisesystemforprimitivestudents*);printf(n*1.add*);printf(n*2.sub*);printf(n*3.mul*);printf(n*4.divide*);printf(n*5.end*n);voidadd()voidsub()voidmul()voiddivide()voidend()第11页/共61页第十一页,共62页。问题:如何定义一个(y)函数第一步:分析函数需要的参数,包括参数的的个数以及每个参

7、数的类型(lixng),第二步:分析函数返回值的类型(lixng),若无返回值,则为void。函数的返回值可看作是函数执行完后需输出的一个数据。第三步:编写函数体说明:参数和返回值是函数之间的接口,即函数之间通过参数和返回值进行通信。参数包括执行该函数时需要的数据信息,以及返回数据的有关信息。第12页/共61页第十二页,共62页。例如:1)求n!:要处理的数据(shj)是n,因此必须有一个参数n,类型为int。返回值为long型。即longfact(intn)2)打印表头:不需输入任何数据(shj)即可执行该函数,因此无参数。执行该函数无返回值,因此函数类型为void。即voidline()3

8、)求两个整数m和n的最小公倍数,执行该功能时必须有两个整型参数,返回值为整型。程序:l8_1_5.cintmin_multiple(intm,intn)(见下页)4)求一批整型数据(shj)(n个)中的最大值。实现该功能的函数的参数有两个:该批数据(shj)的首地址及数据(shj)的个数。返回值为一个整型数。intmax(intdata,intn)第13页/共61页第十三页,共62页。/*例3:计算两个整数的最小公倍数l8_1_5.c*/main()intm,n,min;intmin_multiple(int,int);/*函数(hnsh)声明*/printf(ninputm,n:);scan

9、f(%d%d,&m,&n);min=min_multiple(m,n);/*函数(hnsh)调用*/printf(nbeishu:%d,min);intmin_multiple(intx,inty)/*函数(hnsh)定义*/inti;i=1;while(x*i%y!=0)i+;return(x*i);第14页/共61页第十四页,共62页。8.2函数(hnsh)的调用重点:1、对被调函数的声明2、如何调用一个函数3、主调函数和被调函数之间如何进行数据传递例8.5调用函数fact()求n!(n由用户(yngh)输入)。分三种情况:(1)函数fact()与主函数在同一文件中,且main()在fac

10、t()前面。(2)函数fact()与主函数在同一文件中,且main在fact之后。(3)函数fact与main不再同一程序文件中。第15页/共61页第十五页,共62页。main()/*(1)main()在fact()前面*/intn;longp;longfact(int);/*函数声明*/scanf(%d,&n);p=fact(n);/*函数调用*/printf(n%ld,p);longfact(intm)/*函数定义(dngy)*/inti;longs=1;for(i=1;i=m;i+)s*=i;return(s);/*函数返回*/结论:被调函数在后,需在主调函数中先声明后调用。第16页/共

11、61页第十六页,共62页。/*(2)主调函数在被调函数之后*/longfact(intm)/*函数定义*/inti;longs=1;for(i=1;i=m;i+)s*=i;return(s);main()intn;longp;/*不需函数声明*/scanf(%d,&n);p=fact(n);/*函数调用*/printf(n%ld,p);结论:被调函数先于主调函数被编译,因此在编译主调函数时已知被调函数的类型(lixng)等信息。故不需函数声明。第17页/共61页第十七页,共62页。/*(3)设fact()函数存放在文件f1.c中,则编写主调函数时需用include命令对被调函数声明*/#inc

12、ludemain()intn;longp;scanf(%d,&n);p=fact(n);printf(n%ld,p);结论:该程序的效果与(2)相同,由此可实现将多个文件连接成一个程序。同理,对库函数的调用都要在main函数前用include命令将函数所在的头文件包含(bohn)进来。第18页/共61页第十八页,共62页。函数声明(shngmng)小结:被调函数必须是已存在的函数,通过“函数声明”告知编译系统关于被调函数的有关信息。函数声明的形式:函数类型函数名(参数表);(注意与函数定义(dngy)的区别)1、若被调函数是库函数或用户已编写的函数(与主调函数不在同一文件中),则使用前需在程序

13、的开头用include命令将被调函数的信息包含进来。2、若主调函数与被调函数在同一文件内,且主调函数在前,则必须在主调函数的说明部分或主调函数的前面对被调函数进行说明。3、以下情况下可以省略对被调函数的说明。a)函数类型为整型b)被调函数在主调函数之前定义(dngy)通常,将所有函数的说明集中在程序开头;或将所有函数的信息写入一个文件,编程时用include命令将其包含进来即可。第19页/共61页第十九页,共62页。函数的调用(dioyng)与返回过程小结1、函数调用的一般形式:函数名(实参表)如p=fact(n);printf(“%d”,power(2,n);等注意:实参与形参的类型、个数、

14、顺序(shnx)必须一致。2、调用过程:1)在调用函数时,首先将实参的值赋给形参;再将控制流程转到被调函数;2)然后执行被调函数。3)当被调函数执行到return语句,或执行到被调函数函数体最后的一个大花括号时,控制流程返回到主调函数的断点处继续执行主调函数。如果被调函数有返回值,则控制流程返回的同时将该返回值带回主调函数。第20页/共61页第二十页,共62页。3、函数(hnsh)的返回函数返回的实现:1)函数体中通过执行return语句返回,其格式有3种:return(expression);或returnexpression;或return;2)若函数体中无return语句,当执行到函数末

15、尾(mwi)时自动返回到调用函数。注意:1)函数的返回值最多只有一个,可通过return语句返回主调函数。2)当有多个值需要返回主调函数时,用return语句无法实现,只能通过传地址调用实现。如对数组元素排序等。第21页/共61页第二十一页,共62页。4.参数传递:实参与(cny)形参的结合形参:定义函数时的参数为形参,此时的参数无具体的值,仅仅表示参数的类型、个数、以及在函数体内对其如何处理。其作用是:该函数被调用时用来接收实参的值.实参;调用函数时的参数为实参,它表示该函数要处理的数据的信息,因此(ync)实参必须有确定的值。调用时,将实参的值传给形参。要求:调用函数时,实参与形参的类型、

16、个数必须完全一致。分析例8.4程序的调用过程:明确实参与形参的作用。(传值调用:单向传递)第22页/共61页第二十二页,共62页。例8.4以下程序企图通过调用swap函数,交换(jiohun)主函数中变量x和y中的数据。请观察程序的输出结果。voidswap(inta,intb)intt;printf(2)a=%db=%dn,a,b);t=a;a=b;b=t;printf(3)a=%db=%dn,a,b);main()intx=10,y=20;printf(1)x=%dy=%dn,x,y);swap(x,y);printf(4)x=%dy=%dn,x,y);第23页/共61页第二十三页,共62

17、页。程序运行结果如下:(1)x=10y=20(2)a=10b=20(3)a=20b=10(4)x=10y=20结论:参数的传递是单向的,即只能由实参传给形参,在被调函数中对形参的改变(gibin)的不影响实参的值。第24页/共61页第二十四页,共62页。例8.12编写函数实现:用选择法对n个整数排序。编写主函数实现数据(shj)的输入输出。分析:主程序的算法:S1:输入一批数据(shj)(个数为N),存入一维数组aa。S2:调用函数sort(),对一维数组中的数据(shj)按从小到大的顺序排序。S3:输出数组aa中的各元素。函数sort()的编写:首先,确定函数的类型:void;参数:一维数组

18、的首地址,数据(shj)的个数,共2个;然后编写函数体,实现排序。重点:分析参数的传递,比较传值与传地址的区别,各有何用处?(图示:形参数组与实参数组的结合方式)第25页/共61页第二十五页,共62页。/*主函数(hnsh)*/#defineN10main()intaaN,i;voidsort(intb,intn);printf(nenterintegersforsort;);for(i=0;iN;i+)scanf(%d,&aai);sort(aa,N);/*函数(hnsh)调用*/printf(naftersort:n);for(i=0;iN;i+)printf(%6d,aai);/*函数s

19、ort()*/voidsort(intb,intn)inti,j,t,k;for(i=1;i=n-1;i+)k=0;for(j=1;j=n-i;j+)if(bk=6)even(a);/*函数调用语句*/elseprintf(The%disntevennumbern,a);第31页/共61页第三十一页,共62页。voideven(intx)/*函数(hnsh)定义*/inti;for(i=2;i=x/2;i+)if(isprime(i)if(isprime(x-i)printf(%d=%d+%dn,x,i,x-i);return;intisprime(inta)/*函数(hnsh)定义*/int

20、i,k=sqrt(a);for(i=2;i1)-规律f(1)=1(n=1)-递归结束条件程序:l8_4_1.c分析程序的执行过程,理解递归中的“递进”与“回推”。第33页/共61页第三十三页,共62页。main()/*程序(chngx):L8_4_1.c*/intn;longp;longf(int);/*对被调函数的声明*/printf(ninputn:);scanf(%d,&n);p=f(n);/*函数调用*/printf(nn!=%ld,p);longf(intm)/*函数定义*/longt;if(m=1)t=1;elset=m*f(m-1);/*函数递归调用*/return(t);/*函

21、数的返回*/第34页/共61页第三十四页,共62页。类似的递归问题:1。猴子吃桃:intpeach(intday)intn;if(d=10)n=1;elsen=2*(peach(day+1)+1);returnn;2。猜年龄(ninlng):第一个人说它比第二个人大4岁,第二个人说它比第三个人大4岁,第三个人说它比第四个人大四岁,第四个人10岁,问:第一个人多大?第35页/共61页第三十五页,共62页。8.5局部变量和全局变量指变量的作用范围不同。局部变量:在函数体内定义的变量。作用范围:只在本函数内有效如前面例题中的变量、数组等。全局变量:在函数体外定义的变量作用范围:从定义该变量的位置开始

22、(kish),到本源程序文件结束。第36页/共61页第三十六页,共62页。程序(chngx):/*全局变量x,y*/intx=100;floaty=66.6;f1()floaty=0;/*局部变量y*/printf(“x=%dt”,x);printf(“y=%ft”,y);intz=1;f2()inti;/*局部变量i*/for(i=1;i5;i+)putchar(*);printf(nz=%dt,z);/*全局变量z从定义起至程序(chngx)末起作用*/main()f1();f2();printf(“y=%fn”,y);/*输出全局变量y*/运行(ynxng)结果:x=100y=0.000

23、000*z=1y=66.600000/*全局变量x,y在本程序内起作用*/*局部变量y的作用范围内,全局变量y不作用*/第37页/共61页第三十七页,共62页。intd=1;/*全局变量d*/fun(intp)intd=5;/*局部变量d*/d+=p+;/*使用局部变量d*/printf(%d,d);main()inta=3;fun(a);d+=a+;/*使用全局变量d*/printf(%d,d);运行结果:84结论:在同一源程序文件(wnjin)中,若外部变量与局部变量同名,则在局部变量的作用范围内,外部变量不起作用。第38页/共61页第三十八页,共62页。局部变量和全局变量小结(xioji

24、)局部变量:保证了函数之间的独立性。(常用)全局变量:增加了函数之间数据传递的通道,但降低了函数间的独立性,降低了程序的清晰性,因此副作用太大。除非特别需要时,一般不用。占用内存情况:局部变量仅当他所在的函数被调用时才存在,执行完该函数返回后,该变量不再(bzi)存在全局变量在程序的全部执行过程中一直存在,直至程序执行完,才释放它所占的内存空间第39页/共61页第三十九页,共62页。8.6变量的存储(cnch)类别变量和函数均有两个属性:数据类型和存储类别存储类别指数据在内存(nicn)中的存储方式。根据变量的“生存期”不同,变量的存储类别包含以下四种:自动的:auto静态的:static寄存

25、器的:register外部的:extern第40页/共61页第四十页,共62页。自动(zdng)的(auto)变量函数的形参和在函数中定义的变量(通常省略存储类别,)即隐含指定为自动(zdng)变量。前面17章中的变量均属自动(zdng)变量。自动(zdng)变量在需要时系统给他门分配存储空间,在函数调用结束时自动(zdng)释放这些存储空间。例autointa=2,b=3;与inta=2,b=3;等价。第41页/共61页第四十一页,共62页。静态(jngti)的(static)1、静态局部变量:作用域为本函数内部存储类别为静态存储类,因此其生存期与该函数所在程序运行期间(qjin)相同。即当

26、函数调用结束时能保留原值,在下一次调用该函数时该变量的值是上一次函数调用结束时的值,直至程序运行结束。例(nextpage)第42页/共61页第四十二页,共62页。func(inta,intb)/*例8.6.1*/staticintm=0,i=2;/*静态局部变量m,I*/i+=m+1;m=i+a+b;return(m);main()intk=4,m=1,p;/*局部变量k,m,p*/p=func(k,m);printf(%5d,p);p=func(k,m);printf(%5dn,p);运行结果:817/*图示执行过程(guchng)中变量的存储空间占用及值的变化情况*/第43页/共61页第

27、四十三页,共62页。intd=1;/*全局变量d*/*例8.6.2*/fun(intp)staticintd=5;/*静态(jngti)局部变量d*/d+=p;printf(%5d,d);return(d);main()inta=3;/*自动变量a*/printf(%5dn,fun(a+fun(d);运行结果:61515第44页/共61页第四十四页,共62页。Register变量(binling)registerintk;则给变量k分配的空间为某个寄存器。优点:速度快。只有局部变量和形参可以(ky)定义为register变量。因为机器的寄存器数量有限,因此该类型不常用。第45页/共61页第四十

28、五页,共62页。外部(wib)的(extern)变量用extern声明外部变量(binling),是为了扩展外部变量(binling)的作用域。因外部变量(binling)不常用,因此extern也很少使用。必须使用外部变量(binling)时,一般建议使用静态全局变量(binling)。即在函数体外定义变量(binling)时存储类别为:static如staticinta=2;f()变量(binling)a的作用范围仅限于本源程序文件内。其它程序中即使用externinta;声明也不能引用a。第46页/共61页第四十六页,共62页。8.7内部函数(hnsh)与外部函数(hnsh)外部函数:如

29、不加特别说明,函数都是全局的,即外部的,一个函数可以(ky)调用另一文件中的函数。(项目文件的使用)内部函数:存储类别为static,该函数仅限于本程序文件使用,其它程序不能调用之。第47页/共61页第四十七页,共62页。综合题1编程实现小学生算术练习系统:主菜单包括(boku)5项(加法、减法、乘法、除法、退出),前四项中每一项又包括(boku)子菜单(一级、二级、三级、返回4项),其中一级实现10以内的运算,二级实现50以内的整数运算,三级实现100以内的整数运算;进入某一级后,反复练习(由机器产生两个随机数,用户输入运算结果,输出正确或错误)待结束时给出本级题目中计算正确的百分比。要求每

30、个功能分别用函数实现。程序:l8_t.c第48页/共61页第四十八页,共62页。综合题2自动(zdng)阅卷程序:设单选题20个(2分/题),多选题20个(每题4个供选答案,3分/题,且只要与答案不一致即错)。编写函数实现:阅单选题,阅多选题,阅一个人的答题;编写主函数实现批阅N个人的答题卡(正确答案在主程序中输入)。分析:Main():1)输入正确答案,分别存入一维数组dd,二维数组ss;2)批阅N个人的答题(用循环),将成绩存入数组sc。3)输出每个人的最后成绩。Person():函数类型为int;参数两个:dd,ss;函数体:1)输入某人的答案,分别存入dd1和ss1,2)分别调用函数s

31、ingle()和many()判别对错并计分,返回总成绩。第49页/共61页第四十九页,共62页。Single():函数类型int,参数dd,dd1;函数体:统计数组dd与dd1中相同元素的个数,乘2即得单选题的成绩,返回该成绩。Many():函数类型int,参数ss,ss1;函数体:统计数组ss与数组ss1中对应行元素相同的行数,乘3即得多选题的成绩,并返回。然后(rnhu)分析各函数的具体实现算法。程序1:l8_3_2.c分析程序中的传地址调用,嵌套调用时程序的执行过程。程序2:l8_3_2_q.c定义存放正确答案的数组为全局的,则dd,ss将不作为参数使用。(一般情况使用参数传递)第50页

32、/共61页第五十页,共62页。#includestdio.h/*程序(chngx)1*/#defineN400/*numofperson*/#defineNUM20/*numofquestion*/main()charddNUM+1,ssNUM+15;intscN+1,i;printf(nenterrightanswerofsingleselect:n);printf(n(format:pressenterafterfinishedinputingallofanswers.n);for(i=1;i=NUM;i+)ddi=getchar();getchar();第51页/共61页第五十一页,共6

33、2页。printf(nenteranswerofmultiselect:n);printf(nformat:(pressenterafterinputingaquestion)n);for(i=1;i=NUM;i+)gets(ssi);for(i=1;i=N;i+)sci=person(dd,ss);printf(nno:score:);for(i=1;i=N;i+)printf(n%-6d%-6d,i,sci);第52页/共61页第五十二页,共62页。intperson(chardd,charss5)chardd121,ss1315;ints,i;intsignle(),many();pri

34、ntf(nenteranswerofsingleselect:);for(i=1;i=NUM;i+)dd1i=getchar();getchar();printf(nenteranswerofmultiselect:);for(i=1;i=NUM;i+)gets(ss1i);s=single(dd,dd1)+many(ss,ss1);return(s);第53页/共61页第五十三页,共62页。intsingle(chardd,chardd1)intn=0,i;for(i=1;i=NUM;i+)if(ddi=dd1i)n+;return(2*n);intmany(charss5,charss15

35、)intn=0,i;for(i=1;i1时,计算函数值的过程中又调用函数pp,即递归调用。参数的变化规律为:n-1,n-2。即if(n1)h=2*x*pp(n-1,x)-2*(n-1)*pp(n-2,x)递归结束的条件为:n等于0或n等于1程序:x8_13.c第59页/共61页第五十九页,共62页。通过(tnggu)参数在函数间传递数据X8.14分析:主函数调用4个函数,设函数名分别(fnbi)为average1,average2,max_sc,jun.参数分别(fnbi)为:voidaverage1(floats5,floata)voidaverage(floats5)voidmax_sc(

36、floats5)voidjun(floata)分别(fnbi)实现的功能为:第60页/共61页第六十页,共62页。感谢您的欣赏(xnshng)!第61页/共61页第六十一页,共62页。内容(nirng)总结主要内容:。1)实现模块化设计:将一个大任务分解成一个个的小任务,然后每个任务分别用函数实现。min=min_multiple(m,n)。或将所有函数的信息写入一个文件,编程时用include 命令将其包含进来即可。else t=m*f(m-1)。printf(“y=%ft”,y)。存储类别(libi)指数据在内存中的存储方式。存储类别(libi)为静态存储类,因此其生存期与该函数所在程序运行期间相同。感谢您的欣赏第六十二页,共62页。

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

最新文档


当前位置:首页 > 高等教育 > 研究生课件

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