软件工程第五章编码ppt课件

上传人:博****1 文档编号:568674110 上传时间:2024-07-26 格式:PPT 页数:38 大小:232.50KB
返回 下载 相关 举报
软件工程第五章编码ppt课件_第1页
第1页 / 共38页
软件工程第五章编码ppt课件_第2页
第2页 / 共38页
软件工程第五章编码ppt课件_第3页
第3页 / 共38页
软件工程第五章编码ppt课件_第4页
第4页 / 共38页
软件工程第五章编码ppt课件_第5页
第5页 / 共38页
点击查看更多>>
资源描述

《软件工程第五章编码ppt课件》由会员分享,可在线阅读,更多相关《软件工程第五章编码ppt课件(38页珍藏版)》请在金锄头文库上搜索。

1、软软 件件 工工 程程第五章第五章 编码编码教学内容教学内容5.1 语言的分类语言的分类5.2 选择程序设计语言选择程序设计语言5.3 编码风格编码风格5.4 小结小结5.1 语言的分类语言的分类语言的发展语言的发展机器语言、汇编语言、高级语言、第四代语言机器语言、汇编语言、高级语言、第四代语言语言的类型语言的类型基础语言基础语言Fortran、Cobol、Basic、Algol结构化语言结构化语言Pascal、C、Ada面向对象的语言面向对象的语言Smalltalk、C+、Java、C#5.2 选择程序设计语言选择程序设计语言选择原则选择原则系统用户的要求。系统用户的要求。如果所开发的系统由

2、用户负责维护,用户通常要求用他们熟如果所开发的系统由用户负责维护,用户通常要求用他们熟悉的语言书写程序。悉的语言书写程序。可以使用的编译程序。可以使用的编译程序。运行目标系统的环境中可以提供的编译程序往往限制了可以运行目标系统的环境中可以提供的编译程序往往限制了可以选用的语言的范围。选用的语言的范围。可以得到的软件工具。可以得到的软件工具。如果某种语言有支持程序开发的软件工具可以利用,则目标如果某种语言有支持程序开发的软件工具可以利用,则目标系统的实现和验证都变得比较容易。系统的实现和验证都变得比较容易。工程规模。工程规模。如果工程规模很庞大,现有的语言又不完全适用,可以设计如果工程规模很庞大

3、,现有的语言又不完全适用,可以设计并实现一种供这个工程项目专用的程序设计语言。并实现一种供这个工程项目专用的程序设计语言。程序员的知识。程序员的知识。和其他标准不矛盾,那么应该选择一种已经为程序员和其他标准不矛盾,那么应该选择一种已经为程序员所熟悉的语言。所熟悉的语言。软件可移植性要求。软件可移植性要求。如果目标系统将在几台不同的计算机上运行,或者预如果目标系统将在几台不同的计算机上运行,或者预期的使用寿命很长,那么选择一种标准化程度高、程期的使用寿命很长,那么选择一种标准化程度高、程序可移植性好的语言就是很重要的。序可移植性好的语言就是很重要的。软件的应用领域。软件的应用领域。所谓的通用程序

4、设计语言实际上并不是对所有应用领所谓的通用程序设计语言实际上并不是对所有应用领域都同样适用。域都同样适用。5.2 选择程序设计语言选择程序设计语言5.3 编码风格编码风格源程序代码的逻辑简明清晰、易读易懂是源程序代码的逻辑简明清晰、易读易懂是好程序的一个重要标准好程序的一个重要标准源程序文档化源程序文档化数据说明数据说明语句结构语句结构输入输出方法输入输出方法注:参考注:参考Java语言编程规范语言编程规范http:/ 源程序文档化源程序文档化标识符的命名标识符的命名安排注释安排注释程序的视觉组织程序的视觉组织1、符号的命名、符号的命名符号名即标识符,包括模块名、变量名、常量名、符号名即标识符

5、,包括模块名、变量名、常量名、标号名、子程序名、数据区名以及缓冲区名等。标号名、子程序名、数据区名以及缓冲区名等。这些名字应能反映它所代表的实际东西,应有一这些名字应能反映它所代表的实际东西,应有一定实际意义。例如,表示次数的量用定实际意义。例如,表示次数的量用Times,表,表示总量的用示总量的用Total,表示平均值的用,表示平均值的用Average,表,表示和的量用示和的量用Sum等。等。名字不是越长越好,应当选择精炼的意义明确的名字不是越长越好,应当选择精炼的意义明确的名字。必要时可使用缩写名字,但这时要注意缩名字。必要时可使用缩写名字,但这时要注意缩写规则要一致,并且要给每一个名字加

6、注释。写规则要一致,并且要给每一个名字加注释。在一个程序中,一个变量只应用于一种用途。在一个程序中,一个变量只应用于一种用途。2、程序的注释夹在程序中的注释是程序员与日后的程序夹在程序中的注释是程序员与日后的程序读者之间通信的重要手段。读者之间通信的重要手段。注释决不是可有可无的。注释决不是可有可无的。一些正规的程序文本中,注释行的数量占一些正规的程序文本中,注释行的数量占到整个源程序的到整个源程序的13到到12,甚至更多。,甚至更多。注释分为注释分为序言性注释序言性注释功能性注释功能性注释序言性注释序言性注释通常置于每个程序模块的开头部分,它应当给通常置于每个程序模块的开头部分,它应当给出程

7、序的整体说明,对于理解程序本身具有引出程序的整体说明,对于理解程序本身具有引导作用。有些软件开发部门对序言性注释做了导作用。有些软件开发部门对序言性注释做了明确而严格的规定,要求程序编制者逐项列出。明确而严格的规定,要求程序编制者逐项列出。2、程序的注释有关项目包括:有关项目包括:程序标题;程序标题;有关本模块功能和目的的说明;有关本模块功能和目的的说明;主要算法;主要算法;接口说明:包括调用形式,参数描述,子程序清单;接口说明:包括调用形式,参数描述,子程序清单;有关数据描述:重要的变量及其用途,约束或限制条有关数据描述:重要的变量及其用途,约束或限制条件,以及其它有关信息;件,以及其它有关

8、信息;模块位置:在哪一个源文件中,或隶属于哪一个软件模块位置:在哪一个源文件中,或隶属于哪一个软件包;包;开发简历:模块设计者,复审者,复审日期,修改日开发简历:模块设计者,复审者,复审日期,修改日期及有关说明等。期及有关说明等。2、程序的注释、程序的注释功能性注释功能性注释功能性注释嵌在源程序体中,用以描述其后的功能性注释嵌在源程序体中,用以描述其后的语句或程序段是在做什么工作,或是执行了下语句或程序段是在做什么工作,或是执行了下面的语句会怎么样。而不要解释下面怎么做。面的语句会怎么样。而不要解释下面怎么做。例如,例如,/* ADD AMOUNT TO TOTAL */TOTAL = AMO

9、UNTTOTAL不好。不好。2、程序的注释、程序的注释如果注明把月销售额计入年度总额,便使如果注明把月销售额计入年度总额,便使读者理解了下面语句的意图:读者理解了下面语句的意图:/* ADD MONTHLY-SALES TO ANNUAL-TOTAL */TOTAL = AMOUNTTOTAL要点要点描述一段程序,而不是每一个语句;描述一段程序,而不是每一个语句;用缩进和空行,使程序与注释容易区别;用缩进和空行,使程序与注释容易区别;注释要正确。注释要正确。2、程序的注释、程序的注释空格、空行空格、空行恰当地利用空格,可以突出运算的优先性,避恰当地利用空格,可以突出运算的优先性,避免发生运算的

10、错误。免发生运算的错误。例如,将表达式例如,将表达式(A17)ANDNOT(B49)ORC写成写成(A17) AND NOT (B49) OR C自然的程序段之间可用空行隔开;自然的程序段之间可用空行隔开;2、视觉组织、视觉组织移行移行也叫做向右缩格,它是指程序中的各行不必都也叫做向右缩格,它是指程序中的各行不必都在左端对齐,都从第一格起排列。这样做使程在左端对齐,都从第一格起排列。这样做使程序完全分不清层次关系。序完全分不清层次关系。对于选择语句和循环语句,把其中的程序段语对于选择语句和循环语句,把其中的程序段语句向右做阶梯式移行。使程序的逻辑结构更加句向右做阶梯式移行。使程序的逻辑结构更加

11、清晰。清晰。例如,两重选择结构嵌套,写成下面的移行形例如,两重选择结构嵌套,写成下面的移行形式,层次就清楚得多。式,层次就清楚得多。2、视觉组织、视觉组织IF()THENIF()THENELSEENDIFELSEENDIF2、视觉组织、视觉组织在编写程序时,则需要注意数据说明的风在编写程序时,则需要注意数据说明的风格。格。为了使程序中数据说明更易于理解和维护,为了使程序中数据说明更易于理解和维护,必须注意以下几点:必须注意以下几点:数据说明的次序应当规范化数据说明的次序应当规范化说明语句中变量安排有序化说明语句中变量安排有序化使用注释说明复杂数据结构使用注释说明复杂数据结构5.3.2 数据说明

12、数据说明1.数据说明的次序应当规范化数据说明的次序应当规范化数据说明次序规范化,使数据属性容易查找,数据说明次序规范化,使数据属性容易查找,也有利于测试,排错和维护。也有利于测试,排错和维护。原则上,数据说明的次序与语法无关,其次原则上,数据说明的次序与语法无关,其次序是任意的。但出于阅读、理解和维护的需序是任意的。但出于阅读、理解和维护的需要,最好使其规范化,使说明的先后次序固要,最好使其规范化,使说明的先后次序固定。定。5.3.2 数据说明数据说明例如,在例如,在FORTRAN程序中数据说明次序程序中数据说明次序常量说明常量说明简单变量类型说明简单变量类型说明数组说明数组说明公用数据块说明

13、公用数据块说明所有的文件说明所有的文件说明在类型说明中还可进一步要求。例如,可按如下在类型说明中还可进一步要求。例如,可按如下顺序排列:顺序排列:整型量说明整型量说明实型量说明实型量说明字符量说明字符量说明逻辑量说明逻辑量说明5.3.2 数据说明数据说明2、说明语句中变量安排有序化、说明语句中变量安排有序化当多个变量名在一个说明语句中说明时,应当当多个变量名在一个说明语句中说明时,应当对这些变量按字母的顺序排列。带标号的全程对这些变量按字母的顺序排列。带标号的全程数据数据(如如FORTRAN的公用块的公用块)也应当按字母的也应当按字母的顺序排列。顺序排列。例如,把例如,把integer siz

14、e, length, width, cost, price写成写成integer cost, length, price , size, width 5.3.2 数据说明数据说明3、使用注释说明复杂数据结构、使用注释说明复杂数据结构如果设计了一个复杂的数据结构,应当使用注如果设计了一个复杂的数据结构,应当使用注释来说明在程序实现时这个数据结构的固有特释来说明在程序实现时这个数据结构的固有特点。点。例如例如, 对对PL/1的链表结构和的链表结构和Pascal中用户自定中用户自定义的数据类型,都应当在注释中做必要的补充义的数据类型,都应当在注释中做必要的补充说明。说明。5.3.2 数据说明数据说明

15、在一行内只写一条语句;在一行内只写一条语句;程序编写首先应当考虑清晰性;程序编写首先应当考虑清晰性;5.3.3 语句结构语句结构1. 在一行内只写一条语句在一行内只写一条语句在一行内只写一条语句,并且采取适当的移行在一行内只写一条语句,并且采取适当的移行格式,使程序的逻辑和功能变得更加明确。格式,使程序的逻辑和功能变得更加明确。许多程序设计语言允许在一行内写多个语句。许多程序设计语言允许在一行内写多个语句。但这种方式会使程序可读性变差。因而不可取。但这种方式会使程序可读性变差。因而不可取。5.3.3 语句结构语句结构例如,有一段排序程序例如,有一段排序程序FOR I:=1 TO N1 DO B

16、EGIN T:=I;FOR J:=I1 TO N DO IF AJAT THEN T:=J;IF TI THEN BEGIN WORK:=AT;AT:=AI;AI:=WORK;END END;由于一行中包括了多个语句,掩盖了程序由于一行中包括了多个语句,掩盖了程序的循环结构和条件结构,使其可读性变得的循环结构和条件结构,使其可读性变得很差很差。5.3.3 语句结构语句结构FOR I:=1 TO N-1 DO /改进布局BEGINT:=I;FOR J:=I1 TO N DOIF AJAT THEN T:=J;IF TI THENBEGINWORK:=AT;AT:=AI;AI:=WORK;ENDE

17、ND;5.3.3 语句结构语句结构2. 程序编写首先应考虑清晰性程序编写首先应考虑清晰性程序编写首先应当考虑清晰性,不要刻意追求技程序编写首先应当考虑清晰性,不要刻意追求技巧性,使程序编写得过于紧凑巧性,使程序编写得过于紧凑。例如,有一个用例如,有一个用Pascal语句写出的程序段语句写出的程序段:AI:=AIAT;AT:=AIAT;AI:=AIAT;此段程序可能不易看懂,改一下此段程序可能不易看懂,改一下:WORK:=AT;AT:=AI;AI:=WORK;5.3.3 语句结构语句结构3.程序要能直截了当地说明程序员的用意。程序要能直截了当地说明程序员的用意。4.除非对效率有特殊的要求除非对效

18、率有特殊的要求,程序编写要做到程序编写要做到清晰第一,效率第二。不要为了追求效率清晰第一,效率第二。不要为了追求效率而丧失了清晰性。事实上,程序效率的提而丧失了清晰性。事实上,程序效率的提高主要应通过选择高效的算法来实现。高主要应通过选择高效的算法来实现。5.首先要保证程序正确首先要保证程序正确,然后才要求提高速度。然后才要求提高速度。5.3.3 语句结构语句结构5. 避免使用临时变量而使可读性下降避免使用临时变量而使可读性下降。例如,有的程序员为了追求效率,往往喜欢例如,有的程序员为了追求效率,往往喜欢把表达式把表达式AI1AI;写成写成AIAI; XAI1AI;这样将一句分成两句写,会产生

19、意想不到的问题这样将一句分成两句写,会产生意想不到的问题。5.3.3 语句结构语句结构7. 让编译程序做简单的优化让编译程序做简单的优化。8. 尽可能使用库函数尽可能使用库函数9. 避免不必要的转移。同时如果能保持程序避免不必要的转移。同时如果能保持程序可读性,则不必用可读性,则不必用GO TO语句。语句。10. 尽量只采用三种基本的控制结构来编写程尽量只采用三种基本的控制结构来编写程序。除顺序结构外,使用序。除顺序结构外,使用IF-THEN-ELSE来实现选择结构;使用来实现选择结构;使用DO-UNTIL或或DO-WHILE来实现循环结构。来实现循环结构。5.3.3 语句结构语句结构11.

20、避免使用空的避免使用空的ELSE语句和语句和IFTHEN IF的语句。这种结构容易使读者产生误的语句。这种结构容易使读者产生误解解。IF ( CHARA) THENIF ( CHARZ) THEN PRINT “This is a letter。”ELSE PRINT “This is not a letter。”可能产生二义性问题可能产生二义性问题。5.3.3 语句结构语句结构12. 避免采用过于复杂的条件测试避免采用过于复杂的条件测试。13. 尽量减少使用尽量减少使用“否定否定”条件的条件语句条件的条件语句。例如,如果在程序中出现例如,如果在程序中出现IF NOT ( ( CHAR0) O

21、R ( CHAR9) ) THEN 改成改成IF ( CHAR0) AND ( CHAR9) THEN 不要让读者绕弯子想不要让读者绕弯子想。14. 尽可能用通俗易懂的伪码来描述程序的流程,尽可能用通俗易懂的伪码来描述程序的流程,然后再翻译成必须使用的语言然后再翻译成必须使用的语言。5.3.3 语句结构语句结构15. 数据结构要有利于程序的简化数据结构要有利于程序的简化。16. 要模块化,使模块功能尽可能单一化,模块间要模块化,使模块功能尽可能单一化,模块间的耦合能够清晰可见的耦合能够清晰可见。17. 利用信息隐蔽,确保每一个模块的独立性利用信息隐蔽,确保每一个模块的独立性。18. 不要修补不

22、好的程序,要重新编写。也不要一不要修补不好的程序,要重新编写。也不要一味地追求代码的复用,要重新组织味地追求代码的复用,要重新组织。19. 对太大的程序,要分块编写、测试,然后再集对太大的程序,要分块编写、测试,然后再集成成。20. 对递归定义的数据结构尽量使用递归过程对递归定义的数据结构尽量使用递归过程。5.3.3 语句结构语句结构 输入和输出信息是与用户的使用直接相关输入和输出信息是与用户的使用直接相关的。输入和输出的方式和格式应当尽可能的。输入和输出的方式和格式应当尽可能方便用户的使用。一定要避免因设计不当方便用户的使用。一定要避免因设计不当给用户带来的麻烦给用户带来的麻烦。5.3.4

23、输入和输出输入和输出 不论是批处理的输入输出方式,还是交互式不论是批处理的输入输出方式,还是交互式的输入输出方式,在设计和程序编码时都应考的输入输出方式,在设计和程序编码时都应考虑下列原则虑下列原则:1. 对所有的输入数据都要进行检验,识别错误的输入,对所有的输入数据都要进行检验,识别错误的输入,以保证每个数据的有效性以保证每个数据的有效性;2. 检查输入项的各种重要组合的合理性,必要时报告输检查输入项的各种重要组合的合理性,必要时报告输入状态信息入状态信息;3. 使得输入的步骤和操作尽可能简单,并保持简单的输使得输入的步骤和操作尽可能简单,并保持简单的输入格式入格式;4. 输入数据时,应允许

24、使用自由格式输入输入数据时,应允许使用自由格式输入;5. 应允许缺省值应允许缺省值;5.3.4 输入和输出输入和输出 6. 输入一批数据时,最好使用输入结束标志,输入一批数据时,最好使用输入结束标志,而不要由用户指定输入数据数目而不要由用户指定输入数据数目;7. 在交互式输入时,要在屏幕上使用提示符明确在交互式输入时,要在屏幕上使用提示符明确提示交互输入的请求,指明可使用选择项的种类提示交互输入的请求,指明可使用选择项的种类和取值范围。同时,在数据输入的过程中和输入和取值范围。同时,在数据输入的过程中和输入结束时,也要在屏幕上给出状态信息结束时,也要在屏幕上给出状态信息;8. 当程序设计语言对

25、输入输出格式有严格要求当程序设计语言对输入输出格式有严格要求时,应保持输入格式与输入语句的要求的一致性时,应保持输入格式与输入语句的要求的一致性;9. 给所有的输出加注解,并设计输出报表格式给所有的输出加注解,并设计输出报表格式。5.3.4 输入和输出输入和输出 了解语言的一般分类和特点了解语言的一般分类和特点;了解选择程序设计语言的一般原则了解选择程序设计语言的一般原则;理解和掌握编码的风格理解和掌握编码的风格。 5.4 小结小结 了解语言的一般分类和特点了解语言的一般分类和特点;了解选择程序设计语言的一般原则了解选择程序设计语言的一般原则;理解和掌握编码的风格理解和掌握编码的风格。 5.4

26、 小结小结 从下列关于模块化程序设计的叙述中选出正确的叙述从下列关于模块化程序设计的叙述中选出正确的叙述。程序设计比较方便,但比较难以维护程序设计比较方便,但比较难以维护。便于由多个人分工编制大型程序便于由多个人分工编制大型程序。软件的功能便于扩充软件的功能便于扩充。程序易于理解,也便于排错程序易于理解,也便于排错。在主存储器能够容纳得下的前提下,应使模块尽可能在主存储器能够容纳得下的前提下,应使模块尽可能大,以便减少模块的个数大,以便减少模块的个数。模块之间的接口叫做数据文件模块之间的接口叫做数据文件。只要模块之间的接口关系不变,各模块内部实现细节只要模块之间的接口关系不变,各模块内部实现细节的修改将不会影响别的模块的修改将不会影响别的模块。模块间的单向调用关系叫做模块的层次结构模块间的单向调用关系叫做模块的层次结构。模块越小,模块化的优点越明显。一般来说,模块的模块越小,模块化的优点越明显。一般来说,模块的大小都在大小都在10行以下。行以下。 5.4 小结小结

展开阅读全文
相关资源
正为您匹配相似的精品文档
相关搜索

最新文档


当前位置:首页 > 资格认证/考试 > 自考

电脑版 |金锄头文库版权所有
经营许可证:蜀ICP备13022795号 | 川公网安备 51140202000112号