在上一节中,我们将3个程序文件file1.c、file2.c、file3.c合并成了file4.c(即程序4),程序4中有4个函数:1个主函数,3个子函数。
合并过程简单描述就是:
1、file1.c、file2.c、file3.c拷贝到一个文件file4.c中
2、把从file1.c拷入的main改成max
3、把从file2.c拷入的main改成min
4、把从file3.c拷入的main改成average
5、在file4.c中再新写一个main()函数,调用上面的3个函数
我们看到,4个函数是在一个文件file4.c中的。
其实,说白了, 3合1的目的,就是希望只运行1次,就能实现以前运行3个程序完成的任务:求最大值、最小值和平均值,那么这里,有一个更简便的办法实现程序的3合1,标准C允许我们的一个程序有多个文件, 于是,现在,我们要将(程序1,程序2和程序3)这3个程序重新合并,生成一个全新的程序(程序8),合并过程有4步描述如下:
1、把从file1.c的main改成max,为不破坏file1.c,另存为file8_1.c吧
2、把从file2.c的main改成min,同理另存为file8_2.c
3、把从file3.c的main改成average,同理另存为file8_3.c
4、新建文件file8_4.c,其中再新写一个main()函数,调用上面的3个函数
我们看到,4个函数是分别在4个文件中的。
我们称它为程序8吧,如下所示:
程序8:
================================================================
/********************************************************/
文件1:file8_1.c
#include〈stdio.h〉
void max()
{float a,b,m;
scanf("%f%f",&a,&b);
m=a>b?a:b;
printf("%f/n",m);
}
/********************************************************/
文件2:file8_2.c
#include〈stdio.h〉
void min() {float a,b,m;
scanf("%f%f",&a,&b);
m=a<b?a:b;
printf("%f/n",m);
}
/************************************************/
文件3:file8_3.c
#include〈stdio.h〉
void average()
{float a,b,m;
scanf("%f%f",&a,&b);
m=(a+b)/2;
printf("%f/n",m);
}
/********************************************************/
文件4:file8_4.c
void max();
void min();
void average();
void main()
{
max();
min();
average();
}
================================================================
关于程序8的生成过程的进一步说明
======================================================================================== 在file8_4.c中,在main()之前有3行说明
void max();
void min();
void average();
表示main()即将调用的函数max()、min()、average()
你看出来了吗?这3句和程序中的3个子函数有关系,其实就是3个子函数的函数首部,加了一个分号(;)。你一定要记住在程序中,用函数首部说明一个函数是非常重要的,是必须的,千万不要省略它们;这种做法,在术语上叫函数原型声明。只要有了上面的3个函数说明,就允许这些被调函数和主函数不在一个文件中了,当然和main()在一个文件中也是可以的.通常被调函数的原型声明应放在主调函数所在文件的开头。
========================================================================================
我们看到,这样的合并其实是更简单些,而且,我们也只需要运行一次就可以求3个值了。
聪明的你可能在疑惑,以前我们写程序时,都是把程序代码输入电脑,而后编译连接运行,成功后,保存成一个文件;但现在的程序8却是由4个文件组成的。
一个程序是有多个文件组成,这个程序不简单了吧,我们平时把复杂一点的事情,叫做工程,比如要盖楼房,就叫建筑工程。同理当一个程序是由多个文件组成时,就比以前一个程序是由一个文件组成复杂了,于是在程序设计中,我们把由多文件组成的程序称为工程
复杂的C程序是一个工程,该工程包含一个或多个文件,一个文件又主要包含若干个变量和函数。函数中又有很多复合语句块。
因此C程序分4级:工程----文件-----函数------复合语句块。
还记得什么是复合语句块吗?好吧,让我们回忆一下,我先把第六章的一段原文摘录在下面:
=============================================================================================
=============================================================================================
前面我们说过,用{}把一些语句括起来就成了复合语句。比如上面求5!程序中,右下方的那段:
if(i<=5)
{
p=p*i;
i=i+1;
goto s3;
}
那对{}形成的就是典型的一个复合语句块。
相关推荐
第8章 获得控制:正则表达式元字符 第9章 获得文件句柄 第10章 子程序和函数 第11章 模块化、打包并发送到库 第12章 这个工作要求引用吗 第13章 面向对象的Perl 第14章 tie函数,DBM文件和数据库挂钩 第15章 Perl...
第8章 服务器和客户端信息的获取 210 8.1 字节序 210 8.1.1 大端字节序和小端字节序 210 8.1.2 字节序转换函数 212 8.1.3 一个字节序转换的例子 214 8.2 字符串IP地址和二进制IP地址的转换 217 8.2.1 ...
设计工作的第二步是详细设计,它以概要设计为依据,用于确定软件结构中每个模块的内部细节,为编写程序提供最直接的依据。 详细设计需要从实现每个模块功能的程序算法和模块内部的局部数据结构等细节内容上给出设计...
第8章深入讲解了surface系统的实现原理,分析了surface与activity之间以及surface 与surfaceflinger之间的关系、surfaceflinger的工作原理、surface系统中的帧数据传输以及layerbuffer的工作流程。第9章对vold和...
第1章 最简单的非线性模型 1 什么是非线性 2 非线性演化方程 3 虫口变化的抛物线模型 4 其他简单映射举例 第2章 抛物线映射 5 线段映射的一般讨论 6 稳定和超稳定周期轨道 7 分岔图里的标度性和自相似性 8 分岔图中...
第8章 人机交互与图形用户接口 197 8.1 获取鼠标和键盘消息 198 8.1.1 事件适配器 198 8.1.2 动作适配器 202 8.1.3 事件队列与处理器 203 8.1.4 范例:处理键盘事件.. 205 8.2 三维人机交互工具 207 8.2.1 ...
第二章 多窗口类浏览器设计 11 2.1 多窗口类浏览器需求分析 11 2.1.1 Activity简介 11 2.1.2 Fragment简介 11 2.1.3 多窗口类浏览器需求 12 2.2 多窗口浏览器模式的实现机制 12 2.2.1安卓移动端多窗口浏览器框架 12 ...
第1 章Linux操作系统概述................... .......................................................................... 2 1.1 Linux发展历史........................................................ 2 ...
# 八进制数 (等于十进制数的83) $a = 0x12; # 十六进制数(等于十进制数的18) $a = 1.234; # 浮点数"双精度数" $a = 1.2e3; # 双精度数的指数形式 字符串 字符串可以由单引号或双引号引出的字段定义。注意不同的是...
详细介绍请参阅rainbow(一个长着胡子的彩虹)翻译的展现C#>> ,前几章非常的有趣。 看完了前面几段,我的朋友提出了不同的意见:C#不是Java的Clone,它只是长得有些像Java而已,其实面向对象、中间语言什么的也...
8 Android Android Android Android 开发入门 System System System System Requirements Requirements Requirements Requirements The sections below describe the system and software requirements for ...