《软件工程实践编程幻灯片.ppt》由会员分享,可在线阅读,更多相关《软件工程实践编程幻灯片.ppt(144页珍藏版)》请在taowenge.com淘文阁网|工程机械CAD图纸|机械工程制图|CAD装配图下载|SolidWorks_CaTia_CAD_UG_PROE_设计图分享下载上搜索。
1、软件工程实践编程第1页,共144页,编辑于2022年,星期三第五讲软件实现第2页,共144页,编辑于2022年,星期三内容和目的n编程语言的选择 n编程风格n程序效率n编码要求n静态分析n代码审查n软件调试第3页,共144页,编辑于2022年,星期三编程(编码)n编程是设计的自然结果n编程语言的特性和编程风格会深刻地影响软件的重量和可维护性n软件实现是一个不断变换的过程:设计源程序目标代码机器码n为了保证程序编码的质量,程序员必须深刻理解、熟练掌握并正确地运用程序设计语言的特性。此外,还要求源程序具有良好的结构性和良好的程序设计风格。第4页,共144页,编辑于2022年,星期三编程的目的n编码
2、的目的n是使用选定的程序设计语言,把模块的过程性描述翻译为用该语言书写的源程序(源代码)模块的过程性描述 (不可执行的)源程序(可执行的)编码第5页,共144页,编辑于2022年,星期三结构化程序设计n结构化程序设计是一种设计程序的技术n它采用自顶向下逐步细化的设计方法和单入口(Single entry)单出口(Single exit)的控制结构n这种控制结构包括有:n顺序n选择n循环第6页,共144页,编辑于2022年,星期三结构化程序设计的原则1、使用语言中的顺序、选择、重复等有限的基本控制结构表示程序2、选用的控制结构只准许有一个入口和一个出口 3、程序语句组成容易识别的块(Block)
3、,每块只有一个入口和一个 出口4、复杂结构应该用基本控制结构进行组合嵌套来实现 5、严格控制GOTO语句第7页,共144页,编辑于2022年,星期三编程语言的选择n应用领域n算法及运算的复杂性n软件运行的环境n性能n数据结构的复杂性n软件开发组成员对该语言的熟悉程度第8页,共144页,编辑于2022年,星期三编程风格n程序必须是可以理解的n程序的风格应该强调简单和清晰n影响程序风格的因素有:n源程序文档化n数据说明的方法n语句的结构nI/O的方法第9页,共144页,编辑于2022年,星期三源程序文档化n选择好标识符(变量和标号)的名字n挑选有意义的标识符名字n安排注解n序言式注解(头文件)n功
4、能注解n使程序的结构一目了然n缩进第10页,共144页,编辑于2022年,星期三源程序文档化源程序文档化n n 标识符的命名标识符的命名n n 安排注释安排注释n n 程序的视觉组织程序的视觉组织第11页,共144页,编辑于2022年,星期三符号名的命名符号名的命名n n符号名即标识符,包括符号名即标识符,包括模块名模块名、变量名变量名、常量名常量名、标号名标号名、子程序名子程序名、数据区数据区名名以及以及缓冲区名缓冲区名等。等。n n这些名字应能反映它所代表的实际东西,这些名字应能反映它所代表的实际东西,应有一定实际意义应有一定实际意义。n n例如,表示次数的量用例如,表示次数的量用Time
5、s,表示总量,表示总量的用的用Total,表示平均值的用,表示平均值的用Average,表,表示和的量用示和的量用Sum等。等。第12页,共144页,编辑于2022年,星期三符号名的命名符号名的命名n n名字不是越长越好名字不是越长越好,应当选择精炼的意,应当选择精炼的意义明确的名字。义明确的名字。必要时可使用缩写名字必要时可使用缩写名字,但这时要注意缩写规则要一致,并且要但这时要注意缩写规则要一致,并且要给每一个名字加注释给每一个名字加注释。同时,在一个程。同时,在一个程序中,一个变量只应用于一种用途。序中,一个变量只应用于一种用途。n nNEW.BALANCE.ACCOUNTS.PAYAB
6、LE n nNBALAP n nN 第13页,共144页,编辑于2022年,星期三程序的注释程序的注释 n n夹在程序中的注释是程序员与日后的程夹在程序中的注释是程序员与日后的程序读者之间通信的重要手段。序读者之间通信的重要手段。n n注释决不是可有可无的。注释决不是可有可无的。n n一些正规的程序文本中,注释行的数一些正规的程序文本中,注释行的数量占到整个源程序的量占到整个源程序的13到到12,甚,甚至更多。至更多。n n注释分为序言性注释和功能性注释。注释分为序言性注释和功能性注释。第14页,共144页,编辑于2022年,星期三序言性注释(头文件)n n通常置于每个程序模块的开头部通常置于
7、每个程序模块的开头部分,分,它应当给出程序的整体说明它应当给出程序的整体说明,对于理解程序本身具有引导作用。对于理解程序本身具有引导作用。有些软件开发部门对序言性注释有些软件开发部门对序言性注释做了明确而严格的规定,要求程做了明确而严格的规定,要求程序编制者逐项列出。序编制者逐项列出。第15页,共144页,编辑于2022年,星期三头文件的内容头文件的内容n n 程序标题程序标题程序标题程序标题;n n 有关本模块有关本模块有关本模块有关本模块功能和目的功能和目的功能和目的功能和目的的的的的说明说明说明说明;n n 主要算法主要算法主要算法主要算法;n n 接口说明接口说明接口说明接口说明:包括
8、调用形式,参数描述,子程序清单;:包括调用形式,参数描述,子程序清单;:包括调用形式,参数描述,子程序清单;:包括调用形式,参数描述,子程序清单;n n 有关数据描述有关数据描述有关数据描述有关数据描述:重要的变量及其用途,约束或限制条件,以:重要的变量及其用途,约束或限制条件,以:重要的变量及其用途,约束或限制条件,以:重要的变量及其用途,约束或限制条件,以及其它有关信息;及其它有关信息;及其它有关信息;及其它有关信息;n n 模块位置模块位置模块位置模块位置:在哪一个源文件中,或隶属于哪一个软件包;:在哪一个源文件中,或隶属于哪一个软件包;:在哪一个源文件中,或隶属于哪一个软件包;:在哪一
9、个源文件中,或隶属于哪一个软件包;n n 开发简历开发简历开发简历开发简历:模块设计者,复审者,复审日期,修改日期及有:模块设计者,复审者,复审日期,修改日期及有:模块设计者,复审者,复审日期,修改日期及有:模块设计者,复审者,复审日期,修改日期及有关说明等。关说明等。关说明等。关说明等。第16页,共144页,编辑于2022年,星期三功能性注释n n功能性注释嵌在源程序体中,用以描述功能性注释嵌在源程序体中,用以描述其后的语句或程序段是在做什么工作,其后的语句或程序段是在做什么工作,或是执行了下面的语句会怎么样。而不或是执行了下面的语句会怎么样。而不要解释下面怎么做。要解释下面怎么做。n n例
10、如,例如,/*ADD AMOUNT TO TOTAL*/TOTAL=AMOUNTTOTAL不好。不好。第17页,共144页,编辑于2022年,星期三功能性注释n n如果注明把月销售额计入年度总额,便使读者理解如果注明把月销售额计入年度总额,便使读者理解如果注明把月销售额计入年度总额,便使读者理解如果注明把月销售额计入年度总额,便使读者理解了下面语句的意图:了下面语句的意图:了下面语句的意图:了下面语句的意图:/*ADD MONTHLY-SALES TO ANNUAL-TOTAL/*ADD MONTHLY-SALES TO ANNUAL-TOTAL*/*/TOTAL=AMOUNTTOTAL=AM
11、OUNTTOTALTOTALn n要点要点要点要点n n 描述一段程序,而不是每一个语句;描述一段程序,而不是每一个语句;n n 用缩进和空行,使程序与注释容易区别;用缩进和空行,使程序与注释容易区别;n n 注释要正确。注释要正确。第18页,共144页,编辑于2022年,星期三视觉组织空格、空行和移行n n恰当地利用恰当地利用空格空格,可以,可以突出运算的优先突出运算的优先性性,避免发生运算的错误。,避免发生运算的错误。n n例如例如,将表达式,将表达式(A17)ANDNOT(B49)ORC写成写成(A17)AND NOT(B49)OR Cn n自然的程序段之间可用自然的程序段之间可用空行空
12、行隔开;隔开;第19页,共144页,编辑于2022年,星期三视觉组织n n移行移行移行移行也叫做也叫做也叫做也叫做向右缩格向右缩格向右缩格向右缩格。它是指程序中的各行不必。它是指程序中的各行不必都在左端对齐,都从第一格起排列。这样做使程都在左端对齐,都从第一格起排列。这样做使程序完全分不清层次关系。序完全分不清层次关系。n n对于对于对于对于选择语句选择语句选择语句选择语句和和循环语句循环语句循环语句循环语句,把其中的程序段语句向右,把其中的程序段语句向右,把其中的程序段语句向右,把其中的程序段语句向右做做做做阶梯式移行阶梯式移行。使程序的逻辑结构更加清晰。使程序的逻辑结构更加清晰。n n例如
13、,两重选择结构嵌套,写成下面的移行形式,层例如,两重选择结构嵌套,写成下面的移行形式,层例如,两重选择结构嵌套,写成下面的移行形式,层例如,两重选择结构嵌套,写成下面的移行形式,层次就清楚得多。次就清楚得多。次就清楚得多。次就清楚得多。第20页,共144页,编辑于2022年,星期三视觉组织 IFIF()THENTHEN IF IF()THENTHEN ELSE ELSE ENDIF ENDIF ELSEELSE ENDIFENDIF第21页,共144页,编辑于2022年,星期三数据说明n数据说明的次序应该规范化n多个变量说明时最好按字典数顺序排列n对复杂结构用注解说明第22页,共144页,编辑
14、于2022年,星期三数据说明数据说明n n在设计阶段已经确定了数据结构的组织在设计阶段已经确定了数据结构的组织及其复杂性。在编写程序时,则需要注及其复杂性。在编写程序时,则需要注意数据说明的风格。意数据说明的风格。n n为了使程序中数据说明更易于理解和维为了使程序中数据说明更易于理解和维护,必须注意以下几点:护,必须注意以下几点:1.数据说明的次序应当规范化数据说明的次序应当规范化 2.说明语句中变量安排有序化说明语句中变量安排有序化 3.使用注释说明复杂数据结构使用注释说明复杂数据结构第23页,共144页,编辑于2022年,星期三数据说明的次序应当规范化n n数据说明次序规范化,使数据属性容
15、易数据说明次序规范化,使数据属性容易查找,也有利于测试,排错和维护。查找,也有利于测试,排错和维护。n n原则上,数据说明的次序与语法无关,原则上,数据说明的次序与语法无关,其次序是任意的。但出于阅读、理解和其次序是任意的。但出于阅读、理解和维护的需要,最好使其规范化,使说明维护的需要,最好使其规范化,使说明的先后次序固定。的先后次序固定。第24页,共144页,编辑于2022年,星期三数据说明的次序应当规范化n n在在FORTRAN程序中程序中数据说明次序数据说明次序 常量说明常量说明 简单变量类型说明简单变量类型说明 数组说明数组说明数组说明数组说明 公用数据块说明公用数据块说明公用数据块说
16、明公用数据块说明 所有的文件说明所有的文件说明所有的文件说明所有的文件说明n n在类型说明中还可进在类型说明中还可进一步要求按如下顺序一步要求按如下顺序排列排列 整型量说明整型量说明整型量说明整型量说明 实型量说明实型量说明实型量说明实型量说明 字符量说明字符量说明字符量说明字符量说明 逻辑量说明逻辑量说明逻辑量说明逻辑量说明第25页,共144页,编辑于2022年,星期三说明语句中变量安排有序化n n当当多个变量名在一个说明语句中说明多个变量名在一个说明语句中说明时,时,应当对这些变量应当对这些变量按字母的顺序排列按字母的顺序排列。带。带标号的全程数据标号的全程数据(如如FORTRAN的公用块
17、的公用块)也应当按字母的顺序排列。也应当按字母的顺序排列。n n例如,把例如,把 integer size,length,width,cost,price写成写成 integer cost,length,price,size,width 第26页,共144页,编辑于2022年,星期三使用注释说明复杂数据结构n n如果设计了一个复杂的数据结构,应当如果设计了一个复杂的数据结构,应当使用注释来说明在程序实现时这个数据使用注释来说明在程序实现时这个数据结构的固有特点。结构的固有特点。n n例如例如,对对PL/1的链表结构和的链表结构和Pascal中用户中用户自定义的数据类型,都应当在注释中做自定义的
18、数据类型,都应当在注释中做必要的补充说明。必要的补充说明。第27页,共144页,编辑于2022年,星期三语句结构n每个语句应该简单直接,不应该为提高效率而把语句复杂化n使程序简单易懂n避免采用复杂的条件语句n不要用“否定”条件的条件语句n避免多重的循环嵌套或条件嵌套n用括号使逻辑表达式或算术表达式更为清晰n用空格及有意义的符号使语句内容清晰明确n反问自己“如果这程序不是我编的,我能看懂吗?”第28页,共144页,编辑于2022年,星期三语句结构n n在设计阶段确定了软件的逻辑流结构,在设计阶段确定了软件的逻辑流结构,但构造单个语句则是编码阶段的任务。但构造单个语句则是编码阶段的任务。语句构造力
19、求简单,直接,不能为了片语句构造力求简单,直接,不能为了片面追求效率而使语句复杂化。面追求效率而使语句复杂化。第29页,共144页,编辑于2022年,星期三语句结构n1.在一行内只写一条语句在一行内只写一条语句n在一行内只写一条语句,并且采取适当的移在一行内只写一条语句,并且采取适当的移行格式,使程序的逻辑和功能变得更加明确。行格式,使程序的逻辑和功能变得更加明确。n许多程序设计语言允许许多程序设计语言允许在一行内写多个语句在一行内写多个语句。但这种方式但这种方式会使程序可读性变差会使程序可读性变差。因而不可。因而不可取。取。第30页,共144页,编辑于2022年,星期三语句结构n n例如,有
20、一段排序程序例如,有一段排序程序例如,有一段排序程序例如,有一段排序程序FOR I:=1 TO NFOR I:=1 TO N1 DO BEGIN T:=I1 DO BEGIN T:=I;FOR J:=IFOR J:=I1 TO N DO IF AJAT THEN T:=JAT THEN T:=J;IF TI IF TI THEN BEGIN WORK:=ATTHEN BEGIN WORK:=AT;AT:=AIAT:=AI;AI:=WORKAI:=WORK;END ENDEND END;n n由于一行中包括了多个语句,掩盖了程序的循环由于一行中包括了多个语句,掩盖了程序的循环结构和条件结构,使其
21、可读性变得很差。结构和条件结构,使其可读性变得很差。第31页,共144页,编辑于2022年,星期三语句结构FOR I:=1 TO NFOR I:=1 TO N-1 DO 1 DO /改进布局改进布局改进布局改进布局 BEGIN BEGIN T:=I T:=I;FOR J:=I FOR J:=I1 TO N DO1 TO N DO IF AJ IF AJAT THEN T:=JAT THEN T:=J;IF TI THEN IF TI THEN BEGIN BEGIN WORK:=AT WORK:=AT;AT:=AI AT:=AI;AI:=WORK AI:=WORK;END END END EN
22、D;第32页,共144页,编辑于2022年,星期三语句结构n n2.程序编写首先应当考虑清晰性n n程序编写首先应当考虑清晰性,不要刻意追求技巧性,使程序编程序编写首先应当考虑清晰性,不要刻意追求技巧性,使程序编程序编写首先应当考虑清晰性,不要刻意追求技巧性,使程序编程序编写首先应当考虑清晰性,不要刻意追求技巧性,使程序编写得过于紧凑。写得过于紧凑。写得过于紧凑。写得过于紧凑。n n例如,有一个用例如,有一个用例如,有一个用例如,有一个用 C C 语句写出的程序段:语句写出的程序段:语句写出的程序段:语句写出的程序段:AI=AIAI=AIATAT;AT=AIAT=AIATAT;AI=AIAI=
23、AIATAT;n n此段程序可能不易看懂,有时还需用实际数据试验一下。此段程序可能不易看懂,有时还需用实际数据试验一下。此段程序可能不易看懂,有时还需用实际数据试验一下。此段程序可能不易看懂,有时还需用实际数据试验一下。n n实际上,这段程序的功能就是交换实际上,这段程序的功能就是交换实际上,这段程序的功能就是交换实际上,这段程序的功能就是交换AIAI和和和和ATAT中的内容。目的是为了节省一个中的内容。目的是为了节省一个中的内容。目的是为了节省一个中的内容。目的是为了节省一个工作单元。如果改一下:工作单元。如果改一下:工作单元。如果改一下:工作单元。如果改一下:WORK=ATWORK=AT;
24、AT=AIAT=AI;AI=WORKAI=WORK;就能让读者一目了然了。就能让读者一目了然了。就能让读者一目了然了。就能让读者一目了然了。第33页,共144页,编辑于2022年,星期三语句结构n n3.程序要能直截了当地说明程序员的用意。n n程序编写得要简单,写清楚,直截了当地说明程序员的用程序编写得要简单,写清楚,直截了当地说明程序员的用程序编写得要简单,写清楚,直截了当地说明程序员的用程序编写得要简单,写清楚,直截了当地说明程序员的用意。意。意。意。n n例如,例如,例如,例如,for(for(i i=1;=1;i i=n n;i i+)+)for(for(j j=1;=1;j j=n
25、 n;j j+)+)V V i i j j (i ij j)*()*(j ji i)除法运算()在除数和被除数都是整型量时,其结果除法运算()在除数和被除数都是整型量时,其结果除法运算()在除数和被除数都是整型量时,其结果除法运算()在除数和被除数都是整型量时,其结果只取整数部分,而得到整型量。只取整数部分,而得到整型量。只取整数部分,而得到整型量。只取整数部分,而得到整型量。第34页,共144页,编辑于2022年,星期三语句结构n n 当当当当 i ij j 时时时时,i i/j j=0=0 当当当当 j ji i 时时时时,j j/i i=0=0 得到的数组得到的数组得到的数组得到的数组V
26、 V 是一个单位矩阵是一个单位矩阵是一个单位矩阵是一个单位矩阵 当当当当i i j j时时时时V V i i j j=(=(i ij j)*()*(j ji i)=0)=0 当当当当i ij j时时时时V V i i j j=(=(i ij j)*()*(j ji i)=1)=1n n写成以下的形式,就能让读者直接了解程序编写者的意写成以下的形式,就能让读者直接了解程序编写者的意写成以下的形式,就能让读者直接了解程序编写者的意写成以下的形式,就能让读者直接了解程序编写者的意图。图。图。图。for(for(i i1;1;i i=n n;i i+)+)for(for(j j1;1;j j=n n;
27、j j+)+)if(if(i=ji=j)V V i i j j 1.0;1.0;ELSE ELSE V V i i j j 0.0;0.0;第35页,共144页,编辑于2022年,星期三第36页,共144页,编辑于2022年,星期三语句结构4.除非对效率有特殊的要求除非对效率有特殊的要求,程序编写要程序编写要做到做到清晰第一清晰第一,效率第二效率第二。不要为了追不要为了追求效率而丧失了清晰性。事实上,求效率而丧失了清晰性。事实上,程序程序效率的提高主要应通过选择高效的算法效率的提高主要应通过选择高效的算法来实现。来实现。5.首先要保证首先要保证程序正确程序正确,然后才要求然后才要求提高提高速度
28、速度。反过来说,在使程序高速运行时,反过来说,在使程序高速运行时,首先要保证它是正确的。首先要保证它是正确的。第37页,共144页,编辑于2022年,星期三语句结构n n6.避免避免使用临时变量使用临时变量而使可读性下降。而使可读性下降。n n例如,有的程序员为了追求效率,往往喜例如,有的程序员为了追求效率,往往喜欢把表达式欢把表达式 AI1AI;写成写成 AIAI;XAI1AI;这样将一句分成两句写,会产生意想不到的这样将一句分成两句写,会产生意想不到的问题。问题。第38页,共144页,编辑于2022年,星期三语句结构7.让编译程序做简单的优化。让编译程序做简单的优化。8.尽可能尽可能使用库
29、函数使用库函数9.避免避免不必要的转移不必要的转移。n n同时如果能保持程序可读性,则不必同时如果能保持程序可读性,则不必用用 GO TO语句。语句。第39页,共144页,编辑于2022年,星期三求三个数中最小值的程序求三个数中最小值的程序 IF(X Y)GOTO 30Y)GOTO 30 IF(Y IF(Y Z)GOTO 50 SMALLZ Z GOTO 7030 IF(X 30 IF(X Z)GOTO 60GOTO 60 SMALL SMALLZ Z GOTO 70 GOTO 7050 SMALL50 SMALLY Y GOTO 70 GOTO 7060 SMALL60 SMALLX X70
30、 CONTINUE70 CONTINUE第40页,共144页,编辑于2022年,星期三求三个数中最小值的程序求三个数中最小值的程序 程序只需编写成:程序只需编写成:smallx;if(y small)smally;if(z=a a)if(if(charchar=z z)cout “This is a letter cout “This is a letter。”;else else cout “This is not a letter cout=0&char=0&char=9)不要让读者绕弯子想。不要让读者绕弯子想。不要让读者绕弯子想。不要让读者绕弯子想。第43页,共144页,编辑于2022年
31、,星期三语句结构14.尽可能用尽可能用尽可能用尽可能用通俗易懂的伪码通俗易懂的伪码通俗易懂的伪码通俗易懂的伪码来描述程序的流程,然后来描述程序的流程,然后来描述程序的流程,然后来描述程序的流程,然后再翻译成必须使用的语言。再翻译成必须使用的语言。再翻译成必须使用的语言。再翻译成必须使用的语言。15.15.数据结构要有利于程序的简化。数据结构要有利于程序的简化。数据结构要有利于程序的简化。数据结构要有利于程序的简化。16.16.要要要要模块化模块化模块化模块化,使模块功能尽可能单一化,模块间的耦,使模块功能尽可能单一化,模块间的耦,使模块功能尽可能单一化,模块间的耦,使模块功能尽可能单一化,模块
32、间的耦合能够清晰可见。合能够清晰可见。合能够清晰可见。合能够清晰可见。17.17.利用利用利用利用信息隐蔽信息隐蔽信息隐蔽信息隐蔽,确保每一个模块的独立性。,确保每一个模块的独立性。,确保每一个模块的独立性。,确保每一个模块的独立性。18.18.从从数据数据数据数据出发去构造程序。出发去构造程序。出发去构造程序。出发去构造程序。第44页,共144页,编辑于2022年,星期三语句结构19.不要修补不好的程序,要重新编写。不要修补不好的程序,要重新编写。也不要一味地追求代码的复用,要重新也不要一味地追求代码的复用,要重新组织。组织。20.对太大的程序,要分块编写、测试,对太大的程序,要分块编写、测
33、试,然后再集成。然后再集成。21.对递归定义的数据结构尽量使用递对递归定义的数据结构尽量使用递归过程。归过程。第45页,共144页,编辑于2022年,星期三输入/输出n对批处理I/On符合逻辑地组织输入nI/O出错检查n好的I/O出错恢复功能n清晰的输出报告格式n对交互式I/On简单而有提示的输入方式n完备的出错处理及出错恢复n人机对话输出nI/O格式的一致性n原则:n检查所有输入数据的合法性n检查输入项的各种重要组合是否合理n输入格式要简单n最好采用数据结尾指示符,而不应要求用户规定“输入项目的数量”n交互式I/O要求用户输入时,标明交互输入可选择的种类和范围n输出时保持格式的一致性n设计和
34、标明所有的输出第46页,共144页,编辑于2022年,星期三输入和输出输入和输出n n输入和输出信息是与用户的使用直接相输入和输出信息是与用户的使用直接相关的。输入和输出的方式和格式应当尽关的。输入和输出的方式和格式应当尽可能方便用户的使用。一定要避免因设可能方便用户的使用。一定要避免因设计不当给用户带来的麻烦。计不当给用户带来的麻烦。n n因此,在软件需求分析阶段和设计阶段,因此,在软件需求分析阶段和设计阶段,就应基本确定输入和输出的风格。系统就应基本确定输入和输出的风格。系统能否被用户接受,有时就取决于输入和能否被用户接受,有时就取决于输入和输出的风格。输出的风格。第47页,共144页,编
35、辑于2022年,星期三输入和输出设计和编码原则输入和输出设计和编码原则1.1.对所有的输入数据都要进行检验,识别错误的输入,以保对所有的输入数据都要进行检验,识别错误的输入,以保对所有的输入数据都要进行检验,识别错误的输入,以保对所有的输入数据都要进行检验,识别错误的输入,以保证每个数据的有效性;证每个数据的有效性;证每个数据的有效性;证每个数据的有效性;2.2.检查输入项的各种重要组合的合理性,必要时报告输入状态检查输入项的各种重要组合的合理性,必要时报告输入状态检查输入项的各种重要组合的合理性,必要时报告输入状态检查输入项的各种重要组合的合理性,必要时报告输入状态信息;信息;信息;信息;3
36、.3.使得输入的步骤和操作尽可能简单,并保持简单的输入格式;使得输入的步骤和操作尽可能简单,并保持简单的输入格式;使得输入的步骤和操作尽可能简单,并保持简单的输入格式;使得输入的步骤和操作尽可能简单,并保持简单的输入格式;4.4.输入数据时,应允许使用自由格式输入;输入数据时,应允许使用自由格式输入;输入数据时,应允许使用自由格式输入;输入数据时,应允许使用自由格式输入;5.5.应允许缺省值;应允许缺省值;应允许缺省值;应允许缺省值;6.6.输入一批数据时,最好使用输入结束标志,而不要由用户指定输入一批数据时,最好使用输入结束标志,而不要由用户指定输入一批数据时,最好使用输入结束标志,而不要由
37、用户指定输入一批数据时,最好使用输入结束标志,而不要由用户指定输入数据数目;输入数据数目;输入数据数目;输入数据数目;第48页,共144页,编辑于2022年,星期三输入和输出设计和编码原则输入和输出设计和编码原则7.7.在交互式输入输入时,要在屏幕上使用提示符明确提示交互输在交互式输入输入时,要在屏幕上使用提示符明确提示交互输在交互式输入输入时,要在屏幕上使用提示符明确提示交互输在交互式输入输入时,要在屏幕上使用提示符明确提示交互输入的请求,指明可使用选择项的种类和取值范围。同时,在数入的请求,指明可使用选择项的种类和取值范围。同时,在数入的请求,指明可使用选择项的种类和取值范围。同时,在数入
38、的请求,指明可使用选择项的种类和取值范围。同时,在数据输入的过程中和输入结束时,也要在屏幕上给出状态信息;据输入的过程中和输入结束时,也要在屏幕上给出状态信息;据输入的过程中和输入结束时,也要在屏幕上给出状态信息;据输入的过程中和输入结束时,也要在屏幕上给出状态信息;8.8.当程序设计语言对输入输出格式有严格要求时,应保持输入格当程序设计语言对输入输出格式有严格要求时,应保持输入格当程序设计语言对输入输出格式有严格要求时,应保持输入格当程序设计语言对输入输出格式有严格要求时,应保持输入格式与输入语句的要求的一致性;式与输入语句的要求的一致性;式与输入语句的要求的一致性;式与输入语句的要求的一致
39、性;9.9.给所有的输出加注解,并设计输出报表格式。给所有的输出加注解,并设计输出报表格式。给所有的输出加注解,并设计输出报表格式。给所有的输出加注解,并设计输出报表格式。输入输出风格还受到许多其它因素的输入输出风格还受到许多其它因素的影响。如输入输出设备(例如终端的影响。如输入输出设备(例如终端的类型,图形设备,数字化转换设备等)、类型,图形设备,数字化转换设备等)、用户的熟练程度、以及通信环境等。用户的熟练程度、以及通信环境等。第49页,共144页,编辑于2022年,星期三Wasserman交互系统设计原则原则n把计算机的内部特性掩盖起来不让用户看到n使程序“穿上防弹衣”,保证程序不被用户
40、破坏n如果用户的请求会产生重大的后果,就要提醒用户n在使用此程序时提供联机的帮助条件n按照用户的水平设计输入要求n按照输出设备的速度设计输出信息n区别对待不同类型的用户n保持一致的响应时间n应尽量减少用户处理出错的工作量第50页,共144页,编辑于2022年,星期三效率n要求有效地利用临界资源是自然的nCPU周期和内存单元常被看作临界资源n有关效率的三个格言:n效率是一种性能需求。软件的效率应根据需要,而不是尽可能地高!n好的设计必然提高效率。n程序的简单性与程序的效率往往是一致的。n总之不要去牺牲程序的清晰性、可读性或正确性去追求效率的非本质的提高第51页,共144页,编辑于2022年,星期
41、三源程序的效率n源程序的效率与算法效率直接相关n编程风格会影响运行速度及所需内存的大小n编译器的“优化”特性是提高效率的一种手段n原则:n在具体编程前应简化算术表达式及逻辑表达式n细心地分析多层嵌套循环以确定能否把一些语句或表达式移到循环之外n尽量避免采用多维数组n尽量避免采用指针及复杂的表n采用“快”的算术运算n不要把不同的数据类型混在一起n只要可能就采用整型数的算术运算和布尔表达式第52页,共144页,编辑于2022年,星期三内存效率n大机器领域内存几乎无限制,虚存使“内存效率”不等同于“占用最小的内存”n微机领域内存的限制仍是很现实的问题n采用汇编语言可以节省内存n提高运行效率的技术往往
42、可以同时节省内存n使程序简单是提高内存效率的关键第53页,共144页,编辑于2022年,星期三输入输出效率n提高I/O效率的指导原则:n全部I/O应有缓冲以避免过于频繁的信息交换n对外存应该选用最简单的可接收的存取方式n与外存联系的I/O操作应成块地传送数据n与终端及行式打印机联系的I/O操作应考虑设备的特性,以改进质量与速度n如果“超高效率”的I/O无法被人们理解,则是毫无意义的第54页,共144页,编辑于2022年,星期三程序效率:程序效率:讨论效率的准则讨论效率的准则n n程序的效率是指程序的效率是指程序的效率是指程序的效率是指程序的执行速度程序的执行速度程序的执行速度程序的执行速度及及
43、及及程序所需占用的内存的存程序所需占用的内存的存程序所需占用的内存的存程序所需占用的内存的存储空间储空间储空间储空间。程序编码是最后提高运行速度和节省存储的机。程序编码是最后提高运行速度和节省存储的机。程序编码是最后提高运行速度和节省存储的机。程序编码是最后提高运行速度和节省存储的机会,因此在此阶段不能不考虑程序的效率。让我们首先会,因此在此阶段不能不考虑程序的效率。让我们首先会,因此在此阶段不能不考虑程序的效率。让我们首先会,因此在此阶段不能不考虑程序的效率。让我们首先明确讨论程序效率的几条准则明确讨论程序效率的几条准则明确讨论程序效率的几条准则明确讨论程序效率的几条准则n n效率是一个性能
44、要求,应当在需求分析阶段给出。效率是一个性能要求,应当在需求分析阶段给出。效率是一个性能要求,应当在需求分析阶段给出。效率是一个性能要求,应当在需求分析阶段给出。软件效软件效软件效软件效率以需求为准率以需求为准率以需求为准率以需求为准,不应以人力所及为准。,不应以人力所及为准。,不应以人力所及为准。,不应以人力所及为准。n n 好的设计可以提高效率。好的设计可以提高效率。好的设计可以提高效率。好的设计可以提高效率。n n程序的程序的程序的程序的效率与程序的简单性效率与程序的简单性效率与程序的简单性效率与程序的简单性相关。相关。相关。相关。n n一般说来,任何对效率无重要改善,且对程序的简单性、
45、可读性一般说来,任何对效率无重要改善,且对程序的简单性、可读性一般说来,任何对效率无重要改善,且对程序的简单性、可读性一般说来,任何对效率无重要改善,且对程序的简单性、可读性和正确性不利的程序设计方法都是不可取的。和正确性不利的程序设计方法都是不可取的。和正确性不利的程序设计方法都是不可取的。和正确性不利的程序设计方法都是不可取的。第55页,共144页,编辑于2022年,星期三程序效率:程序效率:算法对效率的影响n n源程序的源程序的效率与详细设计阶段确效率与详细设计阶段确定的算法的效率直接有关定的算法的效率直接有关。在详。在详细设计翻译转换成源程序代码后,细设计翻译转换成源程序代码后,算法效
46、率反映为程序的执行速度算法效率反映为程序的执行速度和存储容量的要求。和存储容量的要求。第56页,共144页,编辑于2022年,星期三设计向程序转换的指导原则设计向程序转换的指导原则 在编程序前,尽可能化简有关的算术表达式和逻辑表达式;在编程序前,尽可能化简有关的算术表达式和逻辑表达式;在编程序前,尽可能化简有关的算术表达式和逻辑表达式;在编程序前,尽可能化简有关的算术表达式和逻辑表达式;仔细检查算法中的嵌套的循环,尽可能将某些语句或表仔细检查算法中的嵌套的循环,尽可能将某些语句或表仔细检查算法中的嵌套的循环,尽可能将某些语句或表仔细检查算法中的嵌套的循环,尽可能将某些语句或表达式移到循环外面;
47、达式移到循环外面;达式移到循环外面;达式移到循环外面;尽量避免使用多维数组;尽量避免使用多维数组;尽量避免使用多维数组;尽量避免使用多维数组;尽量避免使用指针和复杂的表;尽量避免使用指针和复杂的表;尽量避免使用指针和复杂的表;尽量避免使用指针和复杂的表;采用采用采用采用“快速快速快速快速”的算术运算;的算术运算;的算术运算;的算术运算;不要混淆数据类型,避免在表达式中出现类型混杂;不要混淆数据类型,避免在表达式中出现类型混杂;不要混淆数据类型,避免在表达式中出现类型混杂;不要混淆数据类型,避免在表达式中出现类型混杂;尽量采用整数算术表达式和布尔表达式;尽量采用整数算术表达式和布尔表达式;尽量采
48、用整数算术表达式和布尔表达式;尽量采用整数算术表达式和布尔表达式;选用等效的高效率算法;选用等效的高效率算法;选用等效的高效率算法;选用等效的高效率算法;n n编译程序的编译程序的编译程序的编译程序的“优化优化优化优化”功能可自动生成高效率的目标代码功能可自动生成高效率的目标代码功能可自动生成高效率的目标代码功能可自动生成高效率的目标代码第57页,共144页,编辑于2022年,星期三程序效率:程序效率:影响存储器效率的因素n n在大中型计算机系统中,存储限制不再是主要问题。在这种环境下,对在大中型计算机系统中,存储限制不再是主要问题。在这种环境下,对在大中型计算机系统中,存储限制不再是主要问题
49、。在这种环境下,对在大中型计算机系统中,存储限制不再是主要问题。在这种环境下,对内存采取基于操作系统的分页功能的虚拟存储管理内存采取基于操作系统的分页功能的虚拟存储管理内存采取基于操作系统的分页功能的虚拟存储管理内存采取基于操作系统的分页功能的虚拟存储管理。存储效率存储效率存储效率存储效率与操作系统的分页功能直接有关与操作系统的分页功能直接有关与操作系统的分页功能直接有关与操作系统的分页功能直接有关。n n采用结构化程序设计,采用结构化程序设计,采用结构化程序设计,采用结构化程序设计,将程序功能合理分块将程序功能合理分块将程序功能合理分块将程序功能合理分块,使每个模块或一组密切使每个模块或一组
50、密切使每个模块或一组密切使每个模块或一组密切相关模块的程序体积大小与每页的容量相匹配相关模块的程序体积大小与每页的容量相匹配相关模块的程序体积大小与每页的容量相匹配相关模块的程序体积大小与每页的容量相匹配,可减少页面调度,可减少页面调度,可减少页面调度,可减少页面调度,减少内外存交换,提高存储效率。减少内外存交换,提高存储效率。减少内外存交换,提高存储效率。减少内外存交换,提高存储效率。n n微型计算机系统中,存储器的容量对软件设计和编码的制约很大。微型计算机系统中,存储器的容量对软件设计和编码的制约很大。微型计算机系统中,存储器的容量对软件设计和编码的制约很大。微型计算机系统中,存储器的容量