- 1、本文档共37页,可阅读全部内容。
- 2、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。
- 3、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载。
- 4、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
查看更多
电子科大c语言第六节函数
第六章 函数 概述 函数的定义 函数的返回值 函数的调用 函数参数及其传递方式 数组作为函数参数 函数的嵌套调用 函数的递归调用 6.1 概述 模块化程序设计 基本思想:将一个大的程序按功能分割成一些小模块, 特点: 各模块相对独立、功能单一、结构清晰、接口简单 控制了程序设计的复杂性 提高程序的可靠性 缩短开发周期 避免程序开发的重复劳动 易于维护和功能扩充 开发方法:自上向下,逐步分解,分而治之 函数分类 从函数定义的角度 标准函数(库函数):由系统提供 用户自定义函数 从函数形式 无参函数 有参函数 从有无返回值的角度 有返回值函数 无返回值函数 6.2 函数的定义 一般格式 6.3 函数的返回值 返回语句 形式: return(表达式); 或 return 表达式; 或 return; 功能:使程序控制从被调用函数返回到调用函数中,同时把返回值带给调用函数。 说明: 函数中可有多个return语句 若无return语句,遇}时,自动返回调用函数 若函数类型与return语句中表达式值的类型不一致,按前者为准,自动类型转换------函数调用时转换 无返回值函数,可以明确定义为“空类型” (void) 6.4 函数的调用 函数调用形式 函数名(实参表); 说明: 实参与形参个数相等,类型一致,按顺序一一对应 实参表求值顺序,因系统而定 (Turbo C 自右向左) (PASCAL修饰符:自左向右) 例如: main() {int i=2,p; p=f(i, ++i); /*函数调用*/ printf(?%d?,p); } int f(int a,int b) /*函数定义*/ {int c; if (ab) c=1; else if (a==b) c=0; else c=-1; return( c ); } 函数调用方式 函数语句: 例 printstar(); printf(“Hello,World!\n”); 函数表达式: 例 m=max(a,b)*2; 函数参数: 例 printf(“%d”, max(a,b)); m=max(a, max(b,c)); 对被调用函数的声明 对被调用函数要求: 必须是已存在的函数 库函数: #include *.h 用户自定义函数:函数声明 函数声明——函数原型 一般形式: 函数类型 函数名(形参类型 [形参名],….. ); 作用:告诉编译系统函数类型、参数个数及类型,以便检验 函数声明位置:程序的数据说明部分(函数内或外) 对被调用函数的声明(续) 6.5 函数参数及其传递方式 形参与实参 形式参数:定义函数时函数名后面括号中的变量名 实际参数:调用函数时函数名后面括号中的表达式 例:比较两个数并输出大者 参数传递方式 值传递方式 方式:函数调用时,为形参分配单元,并将实参的值复制到形参中;调用结束,形参单元被释放,实参单元仍保留并维持原值 特点: 形参与实参占用不同的内存单元 单向传递 6.6 数组作为函数参数 数组元素作函数实参——值传递 数组名作函数参数——地址传递 实参与形参都应用数组名(或指针变量); 在主调函数与被调函数分别定义数组,且类型应一致; 形参数组大小(多维数组第一维)可不指定; 数组名作参数时,不是“值传送”,而是把实参数组的起始地址传递给形参数组,这样两个数组共占同一段内存,形参数组中个元素的值改变会使实参数组元素的值同时改变。 6.7 函数的嵌套调用 嵌套调用 C规定:函数定义不可嵌套,但可以嵌套调用函数 6.8 函数的递归调用 例: 有5个人坐在一起, 问第5个人多少岁?他说比第4个人大2岁。 问第4个人岁数,他说比第3个人大2岁。 问第3个人岁数,他说比第2个人大2岁。 问第2个人岁数,他说比第1个人大2岁。 最后问第1个人,他说是10岁。请问第5个人多大。 显然,这是一个递归问题。 age(5)=age(4)+2 age(4)=age(3)+2 age(3)=age(2)+2 age(2)=age(1)+2 age(1)=10 可以用一个函数描述上述递归过程: age(int n) /*求年龄的递归函数*/ { int c; /*c用作存放函数的返回值的变量*/ if (n==1) c=10; else c=age(n-1)+2; return(c); } main() { printf(?%d?,
文档评论(0)