[计算机软件及应用]第七章用函数实现模块化程序设计.ppt

[计算机软件及应用]第七章用函数实现模块化程序设计.ppt

[计算机软件及应用]第七章用函数实现模块化程序设计

例7.7 用递归方法求n! 解题思路: 当n=0、1时,n!=1 当n1时,n!=n*(n-1)! 7.7 数组做函数参数 数组做函数参数的目的是把数组中元素的值传递到被调用的函数中。可以通过两种方法实现:一是把数组元素直接传递给被调函数;二是把数组的起始地址传递给被调函数,使被调函数获得数组的入口地址,实现对数组元素的访问。 数组元素作为参数进行传递时,其作用与内存变量相同,是值传递方式。 7.9 变量的存储方式和生存期 在C语言中,每一个变量和函数都有两个属性:数据类型和数据的存储类型。存储类型是指在内存中分配和存储的方法。它可分为两大类:静态存储类型和动态存储类型。具体包含四种:自动的(auto),静态的(static),寄存器的(register)和外部的(extern)。 (1)从作用域角度分,有局部变量和全局变量。它们采用的存储类别如下: 按作用域角度分 局部变量 全局变量 自动变量 静态局部变量 寄存器变量 静态外部变量 外部变量 形式参数可以定义为自动变量或寄存器变量 (2)从变量存在的时间区分,有动态存储和静态存储两种类型。静态存储是程序整个运行时间都存在,而动态存储则是在调用函数时临时分配单元 按生存期分 动态存储 静态存储 自动变量 寄存器变量 静态局部变量 外部变量 形式参数 静态外部变量 (3)从变量值存放的位置来区分,可分为: 按变量值存放的位置分 内存中静态存储区 内存中动态存储区 静态局部变量 静态外部变量 自动变量和形式参数 寄存器变量 外部变量 CPU中的寄存器 (4) 关于作用域和生存期的概念 对一个变量的属性可以从两个方面分析: 作用域:如果一个变量在某个文件或函数范围内是有效的,就称该范围为该变量的作用域。 生存期:如果一个变量值在某一时刻是存在的,则认为这一时刻属于该变量的生存期。 作用域是从空间的角度,生存期是从时间的角度。 二者有联系但不是同一回事。 int a; int main( ) { …f2( );…f1( );… } void f1( ) { auto int b; … f2( ); … } void f2( ) { static int c; …… } a的作用域 b的作用域 c的作用域 文件file1.c a生存期 b生存期 c生存期 main f2 f1 main f2 f1 main 程序执行过程 7.10 关于变量的声明和定义 一般为了叙述方便,把建立存储空间的变量声明称定义,而把不需要建立存储空间的声明称为声明 在函数中出现的对变量的声明(除了用extern声明的以外)都是定义 在函数中对其他函数的声明不是函数的定义 7.11.1 内部函数 如果一个函数只能被本文件中其他函数所调用,它称为内部函数。 在定义内部函数时,在函数名和函数类型的前面加static,即: static 类型名 函数名(形参表) 7.11.2 外部函数 如果在定义函数时,在函数首部的最左端加关键字extern,则此函数是外部函数,可供其他文件调用。 如函数首部可以为 extern int fun (int a, int b) 如果在定义函数时省略extern,则默认为外部函数。 例7.20 有一个字符串,内有若干个字符,今输入一个字符,要求程序将字符串中该字符删去。用外部函数实现。 解题思路: 分别定义3个函数用来输入字符串、删除字符、输出字符串。 按题目要求把以上3个函数分别放在3个文件中。main函数在另一文件中,main函数调用以上3个函数,实现题目的要求。 删除空格的思路 I a m h a p p y \0 …… I a m h a p p y \0 …… 非空 I 空 非空 a 非空 m 空 非空 h 非空 a 非空 p 非空 p 非空 y 结束 \0 \0 i=0 j=0 1 1 2 2 3 3 4 5 4 6 5 7 6 8 7 9 8 10 #include stdio.h int main() { extern void enter_string(char str[]); extern void delete_string(char str[], char ch); extern void print_string(char str[]); char c,str[80]; enter_string(str); scanf(“%c”,c); delete_string(st

文档评论(0)

1亿VIP精品文档

相关文档