C语言-模块化程序设计总结 幻灯片
模块化程序设计总结 模块化程序设计知识点 2、复习函数的定义(P148)(重点) 1、复习程序模块化的概念 (P147) 3、复习函数的编写和调用(P149-P150) 4、复习函数参数的传递和返回值(P149-P152) 5、复习函数递归调用的概念(P164) 6、复习同名异值(P168-P173) 模块化程序设计知识点 * 在模块化的程序设计中,就是对一个复杂的问题分解成若干个功能相对简单的模块,每个模块又可以继续分解成更简单,更小的模块,直到模块划分已经足够简单为止。这种把一个相对复杂的问题分解成若干个小的容易解决的模块来解决问题的方式称为模块化设计方式。 C中最小的模块化单位就是函数。 下图为学员成绩管理系统的模块化简图 学员成绩管理系统 学员注册 成绩管理 成绩登记 成绩查阅 成绩修改 资料修改 学员登记 模块化的概念 * C 语言程序完全是由函数组成。除语言本身提供的库函数和必须包含的 main 函数外,用户还可以根据需要定义任意多个自己的函数。 main() { char ss[10 ]= “12345” ; strcat(ss, “6789”); gets(ss); printf(“%s\n”, ss); } 标准 库函数 函数的概念 函数的概念 * 主函数 库函数 自定义函数 调 用 调 用 调 用 主函数:main函数,可以调用库函数和自定义函数 库函数:printf,scanf,…….. 自定义函数:程序员为完成某项具体的功能,自己写的函数如 CircleArea C语言函数的种类 C语言函数的种类 * 1、调用函数时,函数名必须与调用处的函数名完全一致。 2、实参的个数必须与形参的个数一致。 3、函数必须先定义,后调用。 4、函数可以直接或间接地自己调用自己,称为递归调用。 add(a , b); int add(x , y); 函数的调用规则 函数的调用规则 * 地址传递 方式 若利用参数传递信息时 则有两种传递方式 数据复制的 传递方式 C语言函数的种类 函数的传递方式 C语言的特点之一,就是允许函数的递归调用 其特点是在函数内部直接地调用自己。 递归函数的结构十分简练,对于可以使用递归 算法实现功能的函数,在C 语言中都可以把它们编 写成递归函数。 构造递归函数的关键是寻找递归算法和终结 条件象数学中的递推函数,都可以用C语言中的递 归函数来实现。 函数的递归调用 递归函数的典型例子是 计算阶乘 的函数 n!=1X2X3X…Xn =nX(n-1) X…X3X2X1 =nX(n-1)! 1!=1 递归算法 递归条件 因此, 要想计算出n!,必须计算出 (n-1)!; 计算出 (n-1)!, 必 须计算出(n-2)!; …;由此类推,直到推到 1!=1,返回后即可依次计 算出 2!,3!,…, (n-1)!, n! 。 递归算法和终结条件 * 本讲小结 2、掌握函数的定义(P148)(重点) 1、了解程序模块化的概念 (P147) 3、掌握函数的编写和调用(P149-P150) 4、理解函数参数的传递和返回值(P149-P152) 5、了解函数递归调用的概念(P164) 6、掌握递归函数的使用(P164-P168) 7、理解同名异值(P168-P173) 本讲小结 下次课内容 全局变量的用法 2 函数的嵌套调用 3 1 预编译处理及条件编译 3 3 * * * *