房地产信息管理第5章系统实施、维护与评价.ppt
房地产信息管理房地产信息管理2021/9/180第五章第五章系系统实施、施、维护与与评价价系统分析与系统设计阶段的工作完成以后,开发系统分析与系统设计阶段的工作完成以后,开发人员的工作重点就从分析、设计阶段转入实践阶段。人员的工作重点就从分析、设计阶段转入实践阶段。在此期间,将投入大量的人力、物力及占用较长的时在此期间,将投入大量的人力、物力及占用较长的时间进行间进行程序设计、程序和系统调试、人员培训、系统程序设计、程序和系统调试、人员培训、系统转换转换及及系统评价系统评价等一系列工作,称之为等一系列工作,称之为系统实施系统实施。2021/9/181第一节第一节程序设计程序设计第二节第二节调试调试第三节第三节编写系统说明文件编写系统说明文件第四节第四节系统转换系统转换第五节第五节系统维护系统维护第六节第六节系统评价系统评价2021/9/182第一第一节程序程序设计一、编程方法介绍一、编程方法介绍二、程序设计语言的选择二、程序设计语言的选择三、程序设计的风格三、程序设计的风格四、程序设计的技巧四、程序设计的技巧五、管理信息系统的基本程序模块五、管理信息系统的基本程序模块2021/9/183一、一、编程方法介程方法介绍用计算机对任何问题进行求解,都要把问题转用计算机对任何问题进行求解,都要把问题转化成计算机能够识别的语言程序,即进行程序设计。化成计算机能够识别的语言程序,即进行程序设计。程序设计方法指的是按一定的规则书写程序结构,研程序设计方法指的是按一定的规则书写程序结构,研究的是程序设计的有关原则和方法。究的是程序设计的有关原则和方法。2021/9/1841结结构化程序构化程序设计设计方法方法目前目前软件件设计中,广泛采用中,广泛采用结构化程序构化程序设计方法,方法,这是一种公是一种公认的的较好的程序好的程序设计方法。其主要思方法。其主要思想可以概括想可以概括为:自:自顶向下、逐步求精和模向下、逐步求精和模块化。化。2021/9/185结构化程序设计方法是一种面向数据处理过程的方法,结构化程序设计方法是一种面向数据处理过程的方法,它把数据和过程分离为相互独立的实体。它把数据和过程分离为相互独立的实体。而面向对象的程序设计方法是在本质上不同于结构化而面向对象的程序设计方法是在本质上不同于结构化方法的一种新方法。面向对象程序设计既吸取了结构方法的一种新方法。面向对象程序设计既吸取了结构化方法的优点,又考虑了现实世界与对象空间的映射化方法的优点,又考虑了现实世界与对象空间的映射关系。关系。2面向面向对对象的程序象的程序设计设计方法方法2021/9/186面向对象的基本程序结构被称为面向对象的基本程序结构被称为对象对象。面向对象方法将客观世界看成由许多不同种类的对象构面向对象方法将客观世界看成由许多不同种类的对象构成的。每个对象都有自己的内部状态和内部运动规律,不同成的。每个对象都有自己的内部状态和内部运动规律,不同的对象之间相互联系相互作用,构成了完整的客观世界。的对象之间相互联系相互作用,构成了完整的客观世界。通常用数据描述对象的内部通常用数据描述对象的内部状态状态,并规定了对数据的,并规定了对数据的操操作作。当对象接受到其他对象发送来的。当对象接受到其他对象发送来的消息消息时,可进行相应的时,可进行相应的操作,从而改变其内部状态。操作,从而改变其内部状态。性质相同的对象称为性质相同的对象称为类类。类具有类具有封装性封装性、继承性继承性和和多态性多态性。2021/9/187程序员在程序设计时,将所要解决的问题分解为若程序员在程序设计时,将所要解决的问题分解为若干个类和对象,定义对象的属性和功能,再用消息来描干个类和对象,定义对象的属性和功能,再用消息来描述对象之间的相互联系。将问题中相互联系、相互作用述对象之间的相互联系。将问题中相互联系、相互作用的实体用对象和消息在程序中反映出来,这就是面向对的实体用对象和消息在程序中反映出来,这就是面向对象程序设计方法的主要思想。象程序设计方法的主要思想。现在已经有多种语言支持面向对象的程序设计方法。现在已经有多种语言支持面向对象的程序设计方法。而且每种语言都有完善的软件开发工具。而且每种语言都有完善的软件开发工具。面向对象的设计方法具有抽象性,可重用性等特点。面向对象的设计方法具有抽象性,可重用性等特点。在今后的程序设计中将逐步占据主导地位。在今后的程序设计中将逐步占据主导地位。2021/9/1883.C/S结结构和构和B/S结结构构随着网随着网络技技术,特,特别是国是国际互互联网技网技术的的发展,展,计算算机的机的应用已用已经从从单机机环境境发展到网展到网络上的上的应用。越用。越来越多的来越多的软件要求在网件要求在网络环境下运行。管理信息系境下运行。管理信息系统也也经历了从了从单机机向向网网络环境境发展的展的过程。更多的程。更多的管理信息系管理信息系统是在网是在网络环境下境下实现信息的收集、信息的收集、传递和加工等功能的。和加工等功能的。管理信息系管理信息系统的的软件件结构构应充分考充分考虑到在网到在网络环境下境下的运行效率、可的运行效率、可扩展性和可展性和可维护性等指性等指标。即使最。即使最初开初开发的系的系统不需要在网不需要在网络环境下运行,也境下运行,也应考考虑到将来系到将来系统扩展或向网展或向网络环境移植的可行性。在系境移植的可行性。在系统实现阶段,段,选择程序程序设计方法和程序方法和程序设计语言言时都都应考考虑到系到系统的运行的运行环境和移植的境和移植的问题。2021/9/1893.C/S结结构和构和B/S结结构构v目前,目前,应用比用比较多的网多的网络化化软件件结构有构有C/S结构构和和B/S结构构两种。某些情况下两种。某些情况下,B/S结构具有比构具有比C/S结构更好的构更好的优势,但在某些情况下,但在某些情况下,C/S的特殊的特殊优势还无法被取代。无法被取代。v很多情况下很多情况下,B/S和和C/S需要需要协同使用同使用.2021/9/18103.C/S结结构和构和B/S结结构构vC/S结构指的是客户机服务器(Client/Server)模式的软件结构。v产生于九十年代前期,当时是局域网环境中MIS应用系统的主流结构。应用程序分为服务器端程序和客户机端程序。服务器程序负责管理数据资源(如数据库等),并接受客户机的服务请求(如数据的查询或更新等),向客户机提供所需的数据或服务。客户机程序面向用户,接受用户的应用请求,并通过一定的协议或接口与服务器进行通信,将服务器提供的数据等资源经过处理后提供给用户。vClient Network DB Server2021/9/18113.C/S结结构和构和B/S结结构构vC/S结构能构能够通通过网网络环境完成数据境完成数据资源的共享,适合管理信源的共享,适合管理信息系息系统的一般的一般应用,并且系用,并且系统的开的开发费用用较低、开低、开发周期短。周期短。v同同时,它也存在很多的缺点。使得,它也存在很多的缺点。使得C/S结构的构的应用受到了很大用受到了很大的限制。的限制。1)C/S结构只能适用于中、小规模的局域网。对于大规模的局域网和广域网就不能胜任了。这就限制了这种软件结构的普遍适用性。2)当局域网中的用户数量增加,频繁访问服务器中的数据资源时,服务器的负载急剧增加。系统性能明显下降。3)由于C/S结构的应用程序存在于服务器端和客户机端,并且二者要协同工作。这就给系统的维护工作带来了很多麻烦。通常在对应用程序进行修改、升级时,必须同时对两端的应用程序做出相应的修改,还要更新所有客户端的应用程序。使系统管理和维护工作难以进行。2021/9/18123.C/S结结构和构和B/S结结构构vB/S结构指的是浏览器服务器(Client/Server)模式的软件结构:v由于Web技术迅速发展,C/S体系结构由单一的两个层次,扩展到由表示层(Browser)、功能层(Web Server)与数据库服务层(DB Server)构成的三层分布式结构,简称浏览器服务器(Browser/Server,B/S)模式的软件结构。vB/S结构采用Internet/Intranet技术,使用统一的通信协议TCP/IP和统一的基于Web浏览器的用户界面,适用于广域网环境。一部分事务逻辑在前端实现,但是主要事务逻辑在服务器端实现,这种结构通常设有数据库服务器、Web服务器、应用服务器等。应用程序主要存放在服务器中,客户端只需要配置标准的浏览器。2021/9/1813networkDatabaseWeb ServerApp Server浏览器浏览器2021/9/18143.C/S结结构和构和B/S结结构构v由于B/S结构采用Internet/Intranet技术,以TCP/IP作为通信协议,可以适用于局域网和广域网环境,具有普遍适用性。v由于客户端都是标准的浏览器,各服务器分工明确,所以,整个系统易于扩展,容易管理。v业务逻辑在服务器端实现,在变化时只要修改服务器端即可,易于维护v由于业务逻辑都在服务器端实现,容易造成服务器端负荷过大2021/9/1815二、程序二、程序设计语言的言的选择自自60年代以来已出现了数千种不同的程序设计语言,年代以来已出现了数千种不同的程序设计语言,其中有一小部分得到了广泛的应用。随着计算机技术的发其中有一小部分得到了广泛的应用。随着计算机技术的发展和对计算机软件需求的不断增长,程序设计语言也不断展和对计算机软件需求的不断增长,程序设计语言也不断更新换代。开发人员所能够使用的程序设计语言越来越多,更新换代。开发人员所能够使用的程序设计语言越来越多,从中选择一种合适的语言就显得尤为重要。从中选择一种合适的语言就显得尤为重要。程序设计语言的选择直接关系到新系统的质量。程序程序设计语言的选择直接关系到新系统的质量。程序员应该了解各种常用高级语言的特点,掌握选择语言的标员应该了解各种常用高级语言的特点,掌握选择语言的标准,以便根据问题的需要,合理地选择适当的程序设计语准,以便根据问题的需要,合理地选择适当的程序设计语言。言。2021/9/1816语言的结构化机制与数据管理能力语言的结构化机制与数据管理能力语言可提供的交互功能语言可提供的交互功能有较丰富的软件工具有较丰富的软件工具开发人员的熟练程度开发人员的熟练程度软件可移植性要求软件可移植性要求系统用户的要求系统用户的要求常用以下几常用以下几项作作为语言言选择的的标准准2021/9/18171)应用领域应用领域每种语言都有自己的适用领域。每种语言都有自己的适用领域。FORTRAN适适用于科学领域;用于科学领域;C语言适用于系统软件的开发;汇语言适用于系统软件的开发;汇编语言适用于系统软件的开发或实时处理程序编语言适用于系统软件的开发或实时处理程序.一般的通用语言都具有进行简单的计算和事务处一般的通用语言都具有进行简单的计算和事务处理能力。理能力。2021/9/18182)运行环境运行环境新系统的运行环境包括硬件环境和软件环境。硬件环新系统的运行环境包括硬件环境和软件环境。硬件环境是指计算机的处理速度、硬盘空间、显示器的分辨率、境是指计算机的处理速度、硬盘空间、显示器的分辨率、外部设备的配备情况等。对于档次较低的计算机只能使外部设备的配备情况等。对于档次较低的计算机只能使用对硬件要求不高的语言。同时还要考虑到该语言在今用对硬件要求不高的语言。同时还要考虑到该语言在今后硬件升级时,是否容易用更好的语言对程序进行改写。后硬件升级时,是否容易用更好的语言对程序进行改写。软件环境是指新系统在运行时所需要的支持软件。如软件环境是指新系统在运行时所需要的支持软件。如操作系统、软件开发工具等。操作系统、软件开发工具等。2021/9/18193)程序员是否熟悉程序员是否熟悉程序设计中应选用有发展前途的语言,但也不能一味追程序设计中应选用有发展前途的语言,但也不能一味追求流行的语言。要根据程序员的知识结构,若能在短时间求流行的语言。要根据程序员的知识结构,若能在短时间内熟悉一门新语言,则应选用公认的好语言。否则应优先内熟悉一门新语言,则应选用公认的好语言。否则应优先选用程序员比较熟悉的语言。选用程序员比较熟悉的语言。另外,在语言的选择中还要考虑计算的复杂性,执行效另外,在语言的选择中还要考虑计算的复杂性,执行效率等。率等。2021/9/1820MASMBasic/TrueBasic/TurboBasic/VisualBasicFortranPascal/TurboPascal/DelphiC/C+/TurboC/BorlandC/MSC/VC/BCBJava/Asp/Jsp/PHP.NET(VC.Net,VB.Net,C#,J#)dBase/FoxPro/VFPInfomix/DB2/Oracle/SQLServerPowerBuilder2021/9/1821AutoCADMicroStationGeoMediaMapInfo/MapX/MapXtremeArcView/MapObjects/ArcObjects/ArcMap/ArcSDE/MOIMS/ArcIMSSuperMap/SuperMapIS/2021/9/1822三、程序三、程序设计的的风格格结构化程序设计的基本思想是按由顶向下逐步细结构化程序设计的基本思想是按由顶向下逐步细化的方式,由三种标准控制结构(顺序、选择、循环)化的方式,由三种标准控制结构(顺序、选择、循环)反复嵌套来构造一个程序。反复嵌套来构造一个程序。大多数高级语言都支持结构化程序设计方法。用大多数高级语言都支持结构化程序设计方法。用该方法产生的程序由许多该方法产生的程序由许多“块块”组成,每个模块只有一组成,每个模块只有一个入口和一个出口,程序中一般没有个入口和一个出口,程序中一般没有GOTO语句,这种语句,这种程序称为结构化程序,结构化程序有易于阅读和维护的程序称为结构化程序,结构化程序有易于阅读和维护的优点。优点。2021/9/1823由于程序的可读性对于软件质量有重要影响,因由于程序的可读性对于软件质量有重要影响,因此在程序设计过程中应当充分重视。为了提高程序的此在程序设计过程中应当充分重视。为了提高程序的可读性,在编程风格方面应注意以下几点;可读性,在编程风格方面应注意以下几点;注释注释书写格式书写格式变量名变量名慎用慎用Goto2021/9/18241.程序的注程序的注释注释原则上可以出现在程序中的任何位置,但是注释原则上可以出现在程序中的任何位置,但是如果使注释和程序的结构配合起来则效果更好。如果使注释和程序的结构配合起来则效果更好。注释一般分为两类;注释一般分为两类;序言性注释序言性注释描述性注释描述性注释2021/9/1825序言性注释序言性注释出现在模块的首部,内容应包括:模块功能说明;界出现在模块的首部,内容应包括:模块功能说明;界面描述(如调用语句格式、所有参数的解释和该模块需调用的模块名面描述(如调用语句格式、所有参数的解释和该模块需调用的模块名等);某些重要变量的使用、限制;开发信息(如作者、复查日期、等);某些重要变量的使用、限制;开发信息(如作者、复查日期、修改日期等)。修改日期等)。描述性注释描述性注释嵌在程序之中,用来说明程序段的功能或数据的状态。嵌在程序之中,用来说明程序段的功能或数据的状态。2021/9/1826书写注释时应注意:书写注释时应注意:(1)注释应和程序一致,修改程序时应同时修改注释。)注释应和程序一致,修改程序时应同时修改注释。(2)注释应提供一些程序本身难以表达的信息。)注释应提供一些程序本身难以表达的信息。(3)为了方便用户今后维护,注释中尽量多用汉字。)为了方便用户今后维护,注释中尽量多用汉字。2021/9/18272.程序的程序的书写格式写格式结构化程序设计中一般采用所谓结构化程序设计中一般采用所谓“缩排法缩排法”来写程序,即把同一来写程序,即把同一层次的语句行左端对齐,而下一层的语句则向右边缩进若干格书写,层次的语句行左端对齐,而下一层的语句则向右边缩进若干格书写,它能体现程序逻辑结构的深度。此外,在程序段与段之间,程序与注它能体现程序逻辑结构的深度。此外,在程序段与段之间,程序与注释行之间安排空白行,也有助于阅读。释行之间安排空白行,也有助于阅读。2021/9/18283.变量名的量名的选择变量是由程序员在程序中定义的一些符号,虽然变量变量是由程序员在程序中定义的一些符号,虽然变量名称原则上是在一定规则内由程序员任意定义的,但名称原则上是在一定规则内由程序员任意定义的,但不主张使用类似于不主张使用类似于a、b、a1、b1等这样的变量名,等这样的变量名,变量的命名应选用一些有实际意义的名词。变量的命名应选用一些有实际意义的名词。例如将数据库学生字段的结构定义为如下形式:例如将数据库学生字段的结构定义为如下形式:s(c,n,x,s)。在没有任何说明的情况下,几乎无法知。在没有任何说明的情况下,几乎无法知道这个数据库字段的确切含义。但若把该数据库的字道这个数据库字段的确切含义。但若把该数据库的字段改写为:段改写为:s(code,name,sex,score),则几乎无需,则几乎无需什么说明就能知道字段所代表的含义。什么说明就能知道字段所代表的含义。2021/9/1829变量名应适当选取,使其直观、易于理解和记忆。变量名应适当选取,使其直观、易于理解和记忆。采用有实际意义的变量名;采用有实际意义的变量名;不用过于相似的变量名;不用过于相似的变量名;同一变量名不要具有多种含义。同一变量名不要具有多种含义。此外,在编程前最好能对变量名的选取约定统一的标此外,在编程前最好能对变量名的选取约定统一的标准,以后阅读理解就会方便得多。准,以后阅读理解就会方便得多。2021/9/1830例如,以例如,以i,f,c,s等作变量前缀分别表示该等作变量前缀分别表示该变量的类型,如以下变量:变量的类型,如以下变量:iTempfTempcTempsTemp2021/9/18314.慎重使用慎重使用GOTO语句句使用使用GOTO语句将引起程序的控制路径迂回曲折,使语句将引起程序的控制路径迂回曲折,使程序难以理解。程序难以理解。在在Basic、C等语言中仍保留了等语言中仍保留了GOTO关键字,使用关键字,使用时注意:时注意:(1)要避免不必要的)要避免不必要的GOTO;(2)在迫不得已使用)在迫不得已使用GOTO时,则不要使时,则不要使GOTO相互交相互交叉。叉。2021/9/1832四、程序四、程序设计的技巧的技巧程序设计的主要目的是解决问题,为了更好地程序设计的主要目的是解决问题,为了更好地解决问题,在进行程序设计过程中应该掌握一定解决问题,在进行程序设计过程中应该掌握一定的程序设计技巧,包括对系统分析与设计的充分的程序设计技巧,包括对系统分析与设计的充分理解,熟练运用编程语言,综合运用文字、声音、理解,熟练运用编程语言,综合运用文字、声音、图像,并彼此协调。应能对所用算法进行优化,图像,并彼此协调。应能对所用算法进行优化,使程序有较高的效率。使程序有较高的效率。2021/9/18331.选择好的算法选择好的算法2.算法的优化算法的优化3.充分利用语言特点充分利用语言特点4.模块化与重复使用模块化与重复使用2021/9/18341.选择好的算法好的算法算法是在有限步骤内求解某一问题所使用的一算法是在有限步骤内求解某一问题所使用的一组定义明确的规则。组定义明确的规则。通俗地说,就是计算机解题的过程。在这个过通俗地说,就是计算机解题的过程。在这个过程中,无论是形成解题思路还是编写程序,都是在程中,无论是形成解题思路还是编写程序,都是在实施某种算法。实施某种算法。2021/9/1835一个算法应该具有以下五个重要的特征:一个算法应该具有以下五个重要的特征:有穷性:一个算法必须保证执行有限步之后结束;有穷性:一个算法必须保证执行有限步之后结束;确切性:算法的每一步骤必须有确切的定义;确切性:算法的每一步骤必须有确切的定义;可行性:算法原则上能够精确地运行,而且人们用笔和可行性:算法原则上能够精确地运行,而且人们用笔和纸做有限次运算后即可完成。纸做有限次运算后即可完成。输入:一个算法有输入:一个算法有0个或多个输入,以刻画运算对象的个或多个输入,以刻画运算对象的初始情况,所谓初始情况,所谓0个输入是指算法本身限定了初始条件;个输入是指算法本身限定了初始条件;输出:一个算法有一个或多个输出,以反映对输入数据输出:一个算法有一个或多个输出,以反映对输入数据加工后的结果。没有输出的算法是毫无意义的;加工后的结果。没有输出的算法是毫无意义的;2021/9/1836算法是程序设计的灵魂算法是程序设计的灵魂。可以说,无论是在结构。可以说,无论是在结构化程序设计中,还是在面向对象的程序设计中,没有化程序设计中,还是在面向对象的程序设计中,没有算法的程序不可能是一个好的程序。算法的程序不可能是一个好的程序。-窗体的形状、大小涉及到算法;窗体的形状、大小涉及到算法;-控件自身以及与其它控件的诸多关系需要计算;控件自身以及与其它控件的诸多关系需要计算;-字符串的查找、截取和替换更离不开算法。字符串的查找、截取和替换更离不开算法。求解问题的算法可能有多种,而采用哪种算法则求解问题的算法可能有多种,而采用哪种算法则直接影响到程序的执行效率,好的算法可以有效地使直接影响到程序的执行效率,好的算法可以有效地使用系统资源并且提高执行效率。用系统资源并且提高执行效率。2021/9/18372021/9/18382021/9/18392.算法的算法的优化化2021/9/18402021/9/18412021/9/1842改用一条语句来表达,比如该过程可以表示为:改用一条语句来表达,比如该过程可以表示为:for(i=1,fact=1;i=n;fact=fact*i,i=i+1);2021/9/18433.充分利用充分利用语言特点言特点2021/9/18444.模模块化与重复使用化与重复使用结构化程序设计方法中的模块化,主张将程序结构化程序设计方法中的模块化,主张将程序分解为能完成独立功能并具有清晰界面的程序分解为能完成独立功能并具有清晰界面的程序片断。这样就有利于将大型程序分解为一个个片断。这样就有利于将大型程序分解为一个个小的相互独立,但又密切相关的功能模块。模小的相互独立,但又密切相关的功能模块。模块化也为模块的重复使用提供了可能,例如前块化也为模块的重复使用提供了可能,例如前面的求最大公约数的程序,就可以将其写为一面的求最大公约数的程序,就可以将其写为一个独立函数,供需要用此算法的程序调用。这个独立函数,供需要用此算法的程序调用。这样可以大大提高程序开发速度。样可以大大提高程序开发速度。2021/9/1845五、管理信息系五、管理信息系统的基本程序模的基本程序模块一个管理信息系统的软件往往由很多程序模块组成,这些程序模块一个管理信息系统的软件往往由很多程序模块组成,这些程序模块可以归纳成为几种基本类型,包括控制模块、输入及校验模块、修改或可以归纳成为几种基本类型,包括控制模块、输入及校验模块、修改或更新模块、分类合并模块、计算模块、查询、检索模块、输出模块和预更新模块、分类合并模块、计算模块、查询、检索模块、输出模块和预测、优化模块等。测、优化模块等。2021/9/18461.控制模控制模块控制模块包括主控模块和各级控制模块。控制模控制模块包括主控模块和各级控制模块。控制模块的主要功能是根据用户要求信息,由用户的确定处块的主要功能是根据用户要求信息,由用户的确定处理顺序,然后控制转向各处理模块的入口。理顺序,然后控制转向各处理模块的入口。如:如:形式形式1:Switch(功能选择功能选择ID)case1:;case2:形式形式2:从菜单(或按钮)选择功能:从菜单(或按钮)选择功能2021/9/18472.输入模入模块输入模块主要用来输入数据。输入方式有输入模块主要用来输入数据。输入方式有直接用键盘输入和软盘(文件)录入两种。直接用键盘输入和软盘(文件)录入两种。2021/9/18483.输入数据校入数据校验模模块对已经输入计算机中的数据进行校验,以保证原始对已经输入计算机中的数据进行校验,以保证原始数据的正确性。数据的正确性。例如,某系统中有很多数据的输入框,如学号、姓名、年龄例如,某系统中有很多数据的输入框,如学号、姓名、年龄,可单,可单独编写一个校验模块独编写一个校验模块StructCHECKMSGintCorrectID;AnsiStringErrorMSG;StructCHECKMSG*CheckData(AnsiStringS,intVarNo)2021/9/18494.输出模出模块输出模块用来将计算机的运行结果通过屏幕、输出模块用来将计算机的运行结果通过屏幕、打印机或磁盘等输出给用户。在管理信息系统中,打印机或磁盘等输出给用户。在管理信息系统中,一般都有大量的表格、图表需要输出,因此输出一般都有大量的表格、图表需要输出,因此输出模块的质量直接关系到整个系统的性能。模块的质量直接关系到整个系统的性能。2021/9/18505.处理模理模块(1)文件更新模块程序)文件更新模块程序(2)分类合并程序)分类合并程序(3)计算程序)计算程序(4)数据检索程序)数据检索程序(5)预测或优化程序)预测或优化程序2021/9/1851(1 1)文件更新模)文件更新模块程序程序当系统应用的数据发生变化时,需要修当系统应用的数据发生变化时,需要修改数据文件,如增加、修改、删除记录。改数据文件,如增加、修改、删除记录。2021/9/1852(2 2)分)分类合并程序合并程序分类合并程序的主要功能是对已经建立分类合并程序的主要功能是对已经建立的文件,按某关键字进行分类合并。如耗材的文件,按某关键字进行分类合并。如耗材按其类别进行合并;两个或几个报表进行合按其类别进行合并;两个或几个报表进行合并(合并为并(合并为1张表,字段不变;合并为张表,字段不变;合并为1张表,张表,字段分别来自两张表字段分别来自两张表)。)。2021/9/1853(3 3)计算程序算程序进行计算机处理,包括同类记录和不同进行计算机处理,包括同类记录和不同类记录中各数据项的运算。如某一张表按行类记录中各数据项的运算。如某一张表按行或列进行统计。或列进行统计。2021/9/1854(4 4)数据)数据检索程序索程序是为用户提供查询有关信息的程序,包括输入是为用户提供查询有关信息的程序,包括输入查询要求和输出特定的查询结果。查询要求和输出特定的查询结果。2021/9/1855(5 5)预测或或优化程序化程序使用预测或优化的数学模型,利用管理使用预测或优化的数学模型,利用管理信息系统提供的有关数据,进行计算和分析信息系统提供的有关数据,进行计算和分析并输出结果,用来辅助企业或部门的管理人并输出结果,用来辅助企业或部门的管理人员进行决策。如单纯形法线性规划程序、最员进行决策。如单纯形法线性规划程序、最短路径(最小成本)计算程序。短路径(最小成本)计算程序。2021/9/1856第二第二节调试(体体现编程水平程水平)一、调试过程与原则一、调试过程与原则二、模块调试二、模块调试三、分调三、分调四、总调四、总调五、系统测试五、系统测试2021/9/1857一、一、调试过程与原程与原则在管理信息系统开发周期的各个阶段都不可避免地在管理信息系统开发周期的各个阶段都不可避免地会出现差错,调试的目的在于发现其中的错误并及时纠会出现差错,调试的目的在于发现其中的错误并及时纠正。这是保证系统质量的关键步骤,对于一些较大规模正。这是保证系统质量的关键步骤,对于一些较大规模的系统来说,系统调试的工作量往往占系统开发总工作的系统来说,系统调试的工作量往往占系统开发总工作量的量的40以上。以上。2021/9/18581.调试步步骤一个管理信息系统通常由若干子一个管理信息系统通常由若干子系统组成,每个子系统又由若干模块系统组成,每个子系统又由若干模块(程序)组成。所以通常把调试工作(程序)组成。所以通常把调试工作分为模块(程序)调试、分调(子系分为模块(程序)调试、分调(子系统调试)和总调(系统调试)三个层统调试)和总调(系统调试)三个层次,调试过程依次是模块调试、分调、次,调试过程依次是模块调试、分调、总调。总调。2021/9/18592.调试原原则要想通过彻底的测试并找出全部错误几乎是不可能的要想通过彻底的测试并找出全部错误几乎是不可能的例如一个最简单的程序,例如一个最简单的程序,计算两个整数的和:计算两个整数的和:intx,y,z;scanf(“%d%d”,&x,&y);z=x+y;printf(“Sumofx,yis%d”,z);看看会有看看会有什么错误什么错误?2021/9/1860可能出现的错误:可能出现的错误:1.输入数据非整数输入数据非整数程序中没有检验程序中没有检验2.输入数据格式有问题输入数据格式有问题如输入如输入“32,29”、“32;29”3.输入两个数超出范围输入两个数超出范围4.输入的两个数都在范围内,但两数的和超出范围;输入的两个数都在范围内,但两数的和超出范围;2021/9/1861调试的目的在于发现程序中的错误并及时纠正,所调试的目的在于发现程序中的错误并及时纠正,所以在调试时应想方设法使程序的各个部分都投入运行,以在调试时应想方设法使程序的各个部分都投入运行,力图找出所有错误。错误多少与程序质量有关。即使这力图找出所有错误。错误多少与程序质量有关。即使这样,调试通过也不能证明系统无误,系统交付用户使用样,调试通过也不能证明系统无误,系统交付用户使用以后,在系统的维护阶段仍有可能发现少量错误。以后,在系统的维护阶段仍有可能发现少量错误。因此,调试阶段要考虑的基本问题就是因此,调试阶段要考虑的基本问题就是“经济性经济性”,在一定的开发时间和经费的限制下通过进行有限步骤,在一定的开发时间和经费的限制下通过进行有限步骤操作或执行调试用例,尽可能多地发现一些错误。调试操作或执行调试用例,尽可能多地发现一些错误。调试阶段应注意以下基本原则:阶段应注意以下基本原则:2021/9/1862(1)调试用例应该由)调试用例应该由“输入数据输入数据”和和“预期的输出结果预期的输出结果”组成。在执行程序之前应该对期望的输出有很明确的组成。在执行程序之前应该对期望的输出有很明确的描述,以便调试时将程序的输出与预期结果对照检查。描述,以便调试时将程序的输出与预期结果对照检查。(2)不仅要选用合理的输入数据进行调试,还应选用)不仅要选用合理的输入数据进行调试,还应选用不不合理的甚至错误的输入数据合理的甚至错误的输入数据。为了提高程序的可靠性,。为了提高程序的可靠性,应该认真组织一些异常数据进行调试,并仔细观察和分应该认真组织一些异常数据进行调试,并仔细观察和分析系统的反应。析系统的反应。2021/9/1863(3)除了)除了检查程序是否做了它应该做的工作检查程序是否做了它应该做的工作,还应,还应检查程序是否做了它不检查程序是否做了它不该做的事情该做的事情。如计算一个职工的工资单,程序可能计算全部工资单;程序。如计算一个职工的工资单,程序可能计算全部工资单;程序中多出一段毫无意义的代码;(有人甚至为了某种目的,故意降低可读性,中多出一段毫无意义的代码;(有人甚至为了某种目的,故意降低可读性,在程序中随机插入一些毫无意义的代码,例如,你可以编写一个类似工具在程序中随机插入一些毫无意义的代码,例如,你可以编写一个类似工具程序,将一些语法上正确的程序随机插入另一程序)程序,将一些语法上正确的程序随机插入另一程序)(4)应该长期保留所有的调试用例应该长期保留所有的调试用例,直至该系统被废弃不用为止(以备以,直至该系统被废弃不用为止(以备以后调试或其他测试场合重新利用)后调试或其他测试场合重新利用)2021/9/1864二、模二、模块调试模块(程序)调试的目的是保证每个模块模块(程序)调试的目的是保证每个模块本身能正常运行,在该步调试中所发现的问题本身能正常运行,在该步调试中所发现的问题大都是程序设计或详细设计中的错误。大都是程序设计或详细设计中的错误。模块调试一般分成人工走通和上机调试两模块调试一般分成人工走通和上机调试两步进行。步进行。2021/9/1865三、分三、分调分调也称子系统调试,就是把经过调试的模分调也称子系统调试,就是把经过调试的模块放在一起形成一个子系统来调试。主要是调试块放在一起形成一个子系统来调试。主要是调试各模块之间的协调和通信,即重点调试子系统内各模块之间的协调和通信,即重点调试子系统内各模块的接口。各模块的接口。如数据穿过接口时可能丢失;一如数据穿过接口时可能丢失;一个模块对另一个模块可能存在因疏忽而造成的有个模块对另一个模块可能存在因疏忽而造成的有害影响;把若干个子功能结合起来可能不产生预害影响;把若干个子功能结合起来可能不产生预期的主功能等等。期的主功能等等。2021/9/1866例:例:1.A模块会调用模块会调用B模块,需要测试调用中参数传递(输入、输模块,需要测试调用中参数传递(输入、输出参数)是否正确?出参数)是否正确?2.A调用了调用了B,C,同时,同时A、B、C可能使用过某全局变量,可能使用过某全局变量,如果如果B或或C执行过程中修改过该全局变量,可能导致执行过程中修改过该全局变量,可能导致A的异常。的异常。3.A调用调用B,A运行过程中使用过临时文件运行过程中使用过临时文件tmp.txt,模块,模块B也也使用临时文件使用临时文件tmp.txt(用完删除),这可能导致(用完删除),这可能导致A的异常。的异常。2021/9/1867四、四、总调也称系统调试,它是将经过调试的子系统装也称系统调试,它是将经过调试的子系统装配成一个完整的系统来调试,用以发现系统设计配成一个完整的系统来调试,用以发现系统设计和程序设计中的错误,验证系统的功能是否达到和程序设计中的错误,验证系统的功能是否达到设计说明书的要求。设计说明书的要求。2021/9/1868五、系五、系统测试总调完成后就可将原始系统手工作业方式总调完成后就可将原始系统手工作业方式得出的结果正确的数据作为新系统的输入数据进得出的结果正确的数据作为新系统的输入数据进行行“真实真实”运行,这时除了将结果与手工作业进运行,这时除了将结果与手工作业进行校核外,还应考察系统的有效性、可靠性和运行校核外,还应考察系统的有效性、可靠性和运行效率。系统测试最好请用户一起参加,力求做行效率。系统测试最好请用户一起参加,力求做到到“真实真实”和全面。和全面。2021/9/1869第三第三节系系统说明文件的明文件的组成成系统调试完成后应编写一份详细和全面的系统调试完成后应编写一份详细和全面的系统说明文件。该文件可提交用户作为今后使用、系统说明文件。该文件可提交用户作为今后使用、维护新系统的指导性文档,也是鉴定和验收新系维护新系统的指导性文档,也是鉴定和验收新系统时的技术资料。统时的技术资料。2021/9/18701.系统一般性说明系统一般性说明2.系统开发报告系统开发报告3.程序资料程序资料4.操作说明操作说明2021/9/18711.系统一般性说明系统一般性说明2.系统开发报告系统开发报告3.程序资料程序资料4.操作说明操作说明(1)用户手册。给用户介绍系统全面情况,)用户手册。给用户介绍系统全面情况,包括系统目标、功能和性能的简要说明等。包括系统目标、功能和性能的简要说明等。(2)特殊说明。随着外部环境的变化而使系)特殊说明。随着外部环境的变化而使系统作出相应调整等,这些是不断进行补充和统作出相应调整等,这些是不断进行补充和发表的(如补丁程序说明)。发表的(如补丁程序说明)。2021/9/18721.系统一般性说明系统一般性说明2.系统开发报告系统开发报告3.程序资料程序资料4.操作说明操作说明(1)系统分析说明书;)系统分析说明书;(2)系统设计说明书;)系统设计说明书;(3)系统实施说明。主要涉及到系统分调、)系统实施说明。主要涉及到系统分调、总调过程中某些重要问题的回顾和说明;人员总调过程中某