14.1系统实施概述
系统实施是指把系统的物理模型转换成实际运行系统的全过程。在此期间,将投入大量的人力、物力,占用较长的时间,使用部门将发生组织机构、人员、设备、工作方法和工作流程的较大变革。因此,系统实施必须有严格周密的计划,尤其是不要因为系统的实施而打乱组织的正常工作秩序。系统实施可分为4个主要阶段:程序设计阶段、系统调试阶段、系统转换阶段、系统验收阶段,如图141所示。
一个好的设计方案,只有经过精心实施并付诸实际应用,才能带来实际的效益。在系统实施前,必须努力做好下述几项系统实施的基本任务。
1.前期准备工作
系统实施阶段的人、财、物、技术等都要相对集中,而且对组织机构的影响也非常直接,因此必须做好系统实施前的准备工作。系统分析阶段的系统分析报告和系统设计阶段的系统设计报告是系统实施的最基本依据。在系统实施之前,项目负责人必须对之有较深入的了解,并根据要求组织好有关的准备工作。
(1)制定系统的实施计划
根据系统设计的要求制定系统实现的具体计划,包括机房整装、网络建设、硬软件安装、程序编制、系统的调试与转换等方面的计划。
(2)组织好系统的实施队伍
,,
图141系统的实施步骤图
作。要做到人员职责分工明确,各方面工作情况的信息及时反馈到项目负责人处,能够做到及时发现问题、纠正偏差。
(3)软、硬件与配套设施的准备
在系统的总体规划或项目级的系统分析阶段,已对设备配置作了计划和安排,系统对设备的总体需求已经清楚,除了个别的设备(如某些特殊要求的输入、输出设备)需在系统设计之后才能确定之外,大多数设备在完成系统分析之后就可以进行选购。因此,到了系统实施阶段,就应当做好有关工作场所、机房、通信设施等的准备工作,并且进一步做好系统设备的采购安装和调试工作。
2.信息流程重组
(1)信息流程的重组织和业务规程修订
为了适应新系统的要求,需要对现行系统的信息流程作重新组织,并相应修订原有的业务规程和工作制度,以适应新的变化。
(2)人员培训与宣传教育工作
人员培训包括对系统实施人员的培训和用户的培训。实施人员的培训首先要使他们统一思想,确定统一的实施原则,使各部分能够相互协调地进行。人员培训工作要随着系统的实施进行,直到用户学会操作和维护新系统为止。
3.实现方法、工具和数据准备
在系统设计中确定了系统实施方案,但在具体编码、调试和系统转换过程中,需选择有关的具体实施方法和工具,需准备好有关的数据。大致包含以下几方面:系统平台的硬、软件安装与调试,程序的编制与调试,数据库与文件的建立,信息系统调试(软、硬件结合),、、。
4.系统实施的文档准备
系统实施阶段的输出文档包括程序文档和系统实施报告两大类。
程序文档是今后系统维护、修改、扩充的主要详细技术依据,主要包括程序设计报告、源程序清单及程序调试报告等。程序设计报告的主要内容包括对原设计的修改和补充。因为有少数问题直到编码和调试时才发现,这时应修改和补充模块的有关文档,甚至系统设计的有关文档。另外,程序编制应该按照国家颁布的软件设计规范设计和建立文档。
系统实施报告是系统验收、审计、评价及运行维护的依据,主要有:系统实施计划、设备采购及安装验收报告、业务规程及有关制度、系统调试及试运行情况报告、系统转换及验收报告、系统的操作使用手册等。
14.2程序设计
程序设计是系统实施过程中最为重要的环节。为了保证编程工作正确且顺利地进行,一方面,程序设计人员必须仔细阅读系统设计的全部文档资料,充分理解程序模块的内部过程和外部接口;另一方面,编程人员必须深刻地理解、熟练地掌握和正确地运用程序设计语言及软件开发环境和工具,以保证功能的正确实现。
14.2.1程序设计原则
程序设计又称编码,其任务是使用选定的程序设计语言,把系统设计所得到的各模块的信息处理功能和过程描述转换成能在计算机系统上运行的程序源代码(源程序)。
对程序设计的一项基本的质量要求是程序编码的正确性,即在给定环境下计算机能识别和正确运行所编程序,要满足系统设计的功能要求。源程序还应有可移植性,可以被大多数计算机系统识别、解释或编译和运行。
新系统投入运行后,就要进入使用和维护阶段。软件的测试和维护工作既可能是纠正程序中遗留的问题或错误,也可能是要根据用户的要求进行功能的扩充或性能的改善。这些工作必不可少的需要对源程序进行修改,所以从软件测试和维护的角度出发,编程人员在保证程序正确性的同时,还必须保证源程序的可读性,以便其他人可以读懂和维护。因此,源程序的可读性是编程的一个重要的质量要求。
随着计算机硬件性能的飞速发展,人们对程序设计的要求发生了变化。由强调程序的正确和效率,转而倾向于首先强调程序的可维护性、可靠性和可理解性,其次才是效率。程序效率是指计算机资源(如时间和空间)能否被有效地使用。由于硬件性能的不断完善和提高,程序效率已经不像以前那样举足轻重了;相反,程序设计者的工作效率比程序效率更重要。程序设计者工作效率提高,不仅能减少经费开支,而且也会降低程序的出错率,进而减轻程序维护工作的负担。此外,效率与可维护性和可理解性通常是矛盾的,片面追求程序的运行效率不利于程序设计质量的全面提高。在实际编写程序的过程中,人们往往宁可牺牲一,。
总之,系统程序应具有良好的可靠性、可移植性、可读性、可扩充性、可测试性和可维护性。
14.2.2程序语言选择
在程序设计之前的一项重要工作就是选择适当的程序设计语言。自1960年以来已出现了数千种不同的程序设计语言,但只有一小部分得到了广泛的应用。目前应用较多的程序设计语言主要可分为两大类:汇编语言和高级程序设计语言(包括可视化程序语言)。
1.汇编语言的选择
除下面几种情况选用汇编语言设计外,其余情况一律选用高级程序语言设计。
①软件系统对程序执行时间和使用空间都有严格限制。
②系统硬件是特殊的微处理机,不能使用高级程序设计语言。
③大型系统中某一部分的执行时间要求实时处理或直接依赖于硬件。
2.高级程序语言的选择
选用高级程序语言设计的原则如下。
①根据系统用户的要求来选择,选用户所熟悉的语言编写程序。
②根据运行环境进行选择。不同的运行环境往往要限制程序设计语言。
③根据使用的软件开发工具来选择。充分利用操作方便的软件开发工具,可以提高软件的质量和可靠性。
④根据程序员的知识选择。在应用条件许可时,应选择程序员熟悉的设计语言,提高开发速度,保证程序质量。
⑤根据产品的可移植性要求选择。如果目标系统可能在几种不同的计算机上运行或预期使用时间很长,应选择标准化程度高的、可移植性较好的程序语言。
⑥根据产品的应用领域选择。
3.常用的编程语言
目前比较流行的软件工具一般可分为6类,即一般编程语言、数据库系统、程序生成工具、专用系统开发工具、客户机/服务器型工具及面向对象的编程工具等。
(1)常用的编程语言类
这是指由传统编程工具发展而来的一类程序设计语言。常见的有:PASCAL语言、BASIC语言、C语言、C++语言、COBOL语言、PL/1语言、PROLOG语言、Java语言等。这类工具不具有很强的针对性,但适用范围广,原则上任何代码都可以用它们来编写,但程序设计的工作量可能比较大。
(2)数据库类
目前市场上提供的数据库类产品主要有两种。一种是以PC关系数据库为基础的小型或本地数据库系统,其中最典型的产品有:dBase,Access和FoxBASE及VisualFoxPro等的各种版本。它们的特点是简单易学,方便实用,单机处理不涉及网络。另一种是指目前比较流行的、实际应用比较多的大型网络数据库系统;其中比较典型的系统有:ORACLE,SYBASE,INFORMIX,UDB,SQLSERVER等。这类关系型数据库产品的最大特点是功,。
(3)程序生成工具类
程序生成工具是一种基于常用数据处理功能和程序之间对应关系的自动编程工具。例如,在20世纪80年代中期较为流行的应用系统建造工具(ApplicationBuilder,AB)、屏幕生成工具、报表生成工具及综合程序生成工具等。
(4)系统开发工具类
目前系统开发工具主要有两类,即专用开发工具类和综合开发工具类。专用开发工具类是指对应用领域和待开发功能针对性较强的一类系统开发工具,如一般数据库系统都支持的结构化查询语言SQL(StructuredQueryLanguage)、用于对数据库环境编程的开发工具包SDK(StructuredDevelopmentKits)等。综合开发工具类是指针对一般应用系统和数据处理的系统开发工具。常见的有CASE,TeamEnterpriseDeveloper,VisualC++等。
(5)客户机/服务器工具类
客户机/服务器工具类即所谓的Client/Server方式,是近年来较新的软件开发工具,它继承了传统分布式系统的思想,将数据存放和数据处理分别在服务器和客户机上执行,数据的传输则通过网络进行。这类工具主要有Asp.net,BorlandDelphi.net,VisualStudio.
net等。
(6)面向对象编程工具类
这是目前比较流行的一类开发工具,也是目前很多管理信息系统所采用的开发工具。这类工具主要有VisualC++,BorlandDelphi,VisualBasic,Java,Builder等。虽然使用起来不尽相同,但他们所基于的面向对象的原理是一致的,通常在精通一种语言后,可以很快上手另一种语言。
14.2.3程序设计方法概述
1.结构化程序设计方法
结构化程序设计方法采用程序流程图方法设计程序,是程序设计中引用最为广泛的算法描述方法。程序流程图独立于各种程序设计语言,且比较直观、清晰,易于学习掌握。
按照结构化程序设计的原则,任何程序逻辑都可以用顺序、选择、循环这3种程序流程图的基本结构来表示,并且一个程序的详细执行过程可按“自顶向下、逐步加细”的方式和控制结构为单入口单出口的基本模块结构表示程序逻辑,即所有的程序都可以由这3种基本程序流程的控制结构及其组合来实现。
(1)顺序结构(SEQUENCE结构)
顺序结构表示含有多个连续的处理步骤,按程序书写的先后顺序执行。如图142(a)所示,处理过程从A到B按顺序进行。
(2)选择结构或条件结构(IF—THEN—ELSE结构)由某个逻辑表达式的取值决定选择两个处理加工中的一个。如图142(b)所示,当逻辑表达式P取值为真时执行A,为假时执行B。
(3)循环结构或重复结构
这种结构有两种类型。
“”(DO—WHILE)。,
的处理。如图142(c)所示,从入口处首先测试逻辑表达式P,若P为真,则执行S,然后再回到测试条件处;若P为假,则从出口离开此结构。处理S的重复执行次数由条件P控制,只要条件为真就执行一次。因此处理S中必须包括修改逻辑表达式中的控制变量,否则将无限循环。
另一种称为“直到”型循环结构(DO—UNTIL结构)。这种循环结构与“当”型无本质区别,只是测试条件在处理S之后进行。因此“直到”型循环结构不管条件P为何值,至少要执行一次处理S,如图142(d)所示。
(4)多种情况选择结构或多分支结构(CASE结构)该结构是条件结构的扩充,当被测试的变量有多种可能的取值,而根据不同的值需要选择不同的处理时,可采用这种结构。如图142(e)所示,首先测试表达式P值,若P的值为P1,执行S1,执行后从出口离开此结构;当P的值为其他值时,则执行与之相应的处理。
AAB
SBPPTF
TFTFSBABB
PP(a)(b)(c)(d)(e)
图142程序流程图的基本控制结构
以上控制结构中,顺序结构、条件结构和“当”型循环结构是实现各种处理过程的最基本结构,而“直到”型循环结构和多分支结构是在上述3种基本结构上扩展而来的,可以用这3种基本结构来表示。
此外,还有一种不用GOTO语句、不需要流向线的结构化流程图———NS图,它具有如图143所示的基本结构。在NS图中,每个处理步骤用一个盒子表示,盒子可以嵌套。
盒子只能从上头进入,从下头走出,除此之外无其他出入口。所以盒图限制了随意的控制转移,保证了程序的良好结构。
图143NS图的基本结构