MATLAB编程风格讲座.pdf

上传人:asd****56 文档编号:70322192 上传时间:2023-01-19 格式:PDF 页数:31 大小:428.92KB
返回 下载 相关 举报
MATLAB编程风格讲座.pdf_第1页
第1页 / 共31页
MATLAB编程风格讲座.pdf_第2页
第2页 / 共31页
点击查看更多>>
资源描述

《MATLAB编程风格讲座.pdf》由会员分享,可在线阅读,更多相关《MATLAB编程风格讲座.pdf(31页珍藏版)》请在得力文库 - 分享文档赚钱的网站上搜索。

1、MATLAB 编程风格指南 编程风格指南 MATLAB 编程风格指南编程风格指南 1 0、简介、简介 4 1、命名规则、命名规则 5 1.1、变量、变量(变量的名字应该能够反应他们的意义或者用途)5 变量名应该以小写字母开头的大小写混合形式 5 应用范围大的变量应该具有有意义的变量名,小范围的变量应该用短的变量名 6 前缀 n 应该用在作为数值对象的申明的时候 6 应该遵循的一个有关复数变量的惯例(复数变量的惯例)6 只代表单个实体数据的变量可以加以后缀 No 或者是前缀 i 7 循环变量应该以 i、j、k 前缀 7 否定式的布尔变量命名是应该避免(避免 如 isNotFound 的命名)8

2、缩写形式,即使是通常的大写缩写,也应该于小写字母混合使用 8 避免使用一个关键字或者特殊意义的字作为变量名 8 1.2、常数、常数 9 常数(包括全局变量)用大写字母,下划线分割单词(常数的特点)9 参数可以以某些通用类型名作为前缀(通用类型名作为前缀)9 1.3、结构体、结构体 9 结构体的命名应该以一个大写字母开头 9 结构体的命名应该是暗示性的(implicit),并且不需要包括字段名(fieldname)9 1.3、函数(、函数(函数名应该说明他们的用途)10 函数名应该采用小写字母 getname(.),computetotalwidth()10 函数名应该是具有意义的(加强可读性)

3、10 单输出变量的函数可以根据输出参数命名(mean(.),standarderror(.))11 没有输出变量或者返回值为句柄的函数应该根据其实现的功能命名 11 前缀 get/set 应该作为访问对象或者属性的保留前缀 11 前缀 compute 应该用在计算某些量的函数的地方(提示有大计算量)11 前缀 find 可以用在那些具有查询功能的函数的地方(提示查询)12 前缀 initialize 可以用在对象或者是概念建立的地方(提示初始化)12 前缀 is 应该用在布尔函数的命名的地方(相关帮助指令应该一读)12 补足型(complement)名称应该用在补足型(complement)操

4、作的地方 12 避免无意识地覆盖(shadowing)(勿重复命名,否则有不可预期的错误)13 1.4、概要、概要 13 命名多维变量与常量应该具有单位后缀 13 命名中应该避免缩写(尽可能完整一些,可读性)13 考虑使得名字可以拼读 14 所有的命名都应该以英语的形式写出 14 2、文件与程序结构、文件与程序结构 14 1 模块化 14 确保交互过程清晰 15 分割(partitioning)(一个函数做一件事)15 利用现有的函数(发挥 Matlab 的优势)15 任何在多个 m 文件中出现的代码块都应该考虑用函数的形式封装起来(多次重复代码考虑函数封装)15 子函数 15 测试脚本(保证

5、每一底层程序的可靠性)16 3、输入输出、输入输出 16 3.1、编写输入/输出模块 16 3.2、格式化输出使得其易于利用 16 4、基本语句、基本语句 17 4.1、变量与常数、变量与常数 17 变量不应该重复使用(赋予为不同意义),除非因为内存限制的需要 17 同种类型的相近的变量可以在同一个语句中定义 17 不相近的变量应该不要在同一个语句中定义 17 注意在文件开始部分的注释中为重要变量编写文档 17 注意在语句行注释的最后为常数编写文档 17 4.2、全局变量、全局变量 18 应该尽量少地使用全局变量 18 应该尽量少用全局常量 18 4.3、循环语句、循环语句 18 循环变量应该

6、在循环开始前立即被赋值 18 在循环中应该尽量少用 break 与 continue 19 在嵌套式循环的时候应该在 end 行加上注释 19 4.4、条件语句、条件语句 19 应该避免复杂的条件表示式,而采用临时逻辑变量进行替代 19 在 if else 结构的时候,发生较频繁的事件应该放在 if 部分,例外情况放在 else 部分 20 条件表达式 if 0 是应该避免的,除非在对临时程序块进行注释的时候 20 一个 switch 语句应该包含 otherwise 条件 20 switch 变量应该通常是字符串 string 21 4.4、小结、小结 21 避免含糊代码(清楚是核心问题)2

7、1 采用附加说明 22 尽量在表达式中少用数字。可能会改变的数字应该用常数代替 22 浮点常数应该在小数点前面写上一个阿拉伯数据 22 浮点数的比较应该要小心 23 5、排版、注释与文档、排版、注释与文档 23 5.1、排版、排版 23 5.2、应该将代码内容控制在前、应该将代码内容控制在前 80 列之内列之内 23 在恰当的地方应该将行进行切分 24 5.2、基本缩排应该是、基本缩排应该是 3 或者或者 4 个空格个空格 24 25.3、应该与、应该与 MATLAB 编辑器的缩排一致编辑器的缩排一致 25 通常情况下,一行代码应该只包含一个可执行语句 25 短的单个 if,for 或者 wh

8、ile 语句可以写在一行 25 5.4、空白空格、空白空格 25 在=,&,与|前后加上空格 26 常规的操作符两边可以加上空格 26 逗号后面可以加上空格 26 分号或者同一行多条指令的逗号之后应该加上一个空格字符 26 关键字后面应该加上空格 27 一个块(block)内部的一个逻辑组语句应该通过一个空白行将其分隔开 27 块(blocks)之间应该用多行空白行分隔 27 通过排列成行列整齐的方式来加强可读性 27 5.5、注释、注释 27 注释不能够改变写得很糟糕的代码效果 28 注释文字应该简洁易读 28 函数头部的注释应该支持利用 help 与 lookfor 查询 28 函数头部的

9、注释应该讨论对输入参数的特殊要求等 28 函数头的注释应该描述其任何副作用(side effects)29 通常情况下,函数头注释的最后一句应该是重申函数语句行 29 在函数头注释中将函数名用大写的形式表达是一个有争议性的规则 29 避免在函数头说明的 help 打印输出中的混乱 29 所有的注释语句应该用英语写作 29 5.5、文档、文档 30 文档规范化 30 首先考虑书写文档 30 修改 30 参考文献参考文献 31 Richard Johnson Version 1.5,Oct.2002 版权;Datatool 所有 翻译:Genial USTC“Language is like a

10、cracked kettle on which we beat tuned to dance to,while all the time we long to move the stars to pity.”Gustave Flaubert,in Madame Bovary 30、简介、简介 有关 MATLAB 代码的建议通常强调的是效率,譬如说有关“不要用循环”等的建议,本指南与之不同。本指南主要考虑的是代码(格式)的正确性、清晰性与通用性。本指南的目的在于帮助写出更可能正确、易于理解、更具有共享性与更利于维护的代码。正如 Brian Kernighan 写道:“Well-written p

11、rograms are better than badly-written onesthey have fewer errors and are easier to debug and to modifyso it is important to think about style from the beginning.”(良好的写作规范的程序比糟糕的写作规范的要好,因为他们具有较少的错误、易于调试与修改,因此,从一开始就考虑风格是很重要的)。本指南列举的 MATLAB 代码编写的建议在软件开发小组实际工作中得到一致性的认可。本指南与 C、C与 Java 的同类手册在整体上是相似的,但是针对

12、MATLAB 的特征与历史进行了修正。指南中的建议是基于多种其他代码语言的指南与个人经验而来的。指南主要是针对 MATLAB 而写的,但是它对于相近的语言,如 Octave、Scilab 和O-Matrix 等的编程也有所帮助。指南不是戒律,其目的在于简洁易懂地帮助程序员写出好的代码。许多组织有理由偏离这个目的。“You got to know the rules before you can break em.Otherwise its no fun.”Sonny Crockett in Miami Vice MATLAB 是 MathWorks 公司的注册商标,在本指南中,缩写 TMW 指

13、The Mathworks 公司。4本著作献给那些致力于仔细提高进步的人们。1、命名规则、命名规则 Pathrick Raume:“A rose by any other name confues the issue。”(玫瑰如果以其他名字则会导致事情的混乱)一个开发团体建立一个命名规则可能会成为一个可笑的争议性问题。本节描述了一个常用的规则。它对于单个的程序员理解命名规则特别有用。1.1、变量、变量(变量的名字应该能够反应他们的意义或者用途)(变量的名字应该能够反应他们的意义或者用途)变量名应该以小写字母开头的大小写混合形式变量名应该以小写字母开头的大小写混合形式 譬如:linearity,

14、credibleThreat,qualityofLife 等。这在 C开发团体中是普遍实用的。TMW 有时候以大写字母开头命名一个变量名,但是这种用法在其他的语言中通常作为类型或者结果的保留用法。分割复合变量名的各个部分中间通常有两种做法,前面例子的这种(以大写字母分 MATLAB 编程风格指南 Richard Johnson 著 Genial 译)是其中的一种,虽然可读性比较好,但是在其他语言变量名中并不很常用。另外一种考虑的方法是在变量名中采用下划线,但是下划线在 MATLAB 的 Tex 解释程序中会将其翻译为下标转换符。5 应用应用范围大的变量范围大的变量应该具有有意义的变量名,应该具

15、有有意义的变量名,小范围的变量小范围的变量应该用短的变量名应该用短的变量名 实际上,大多数变量都应该具有有意义的变量名,短变量名通常作为结构申明时候必须阐明意义的情况下的变量的保留用法。当然,作为“草稿变量”的的临时存储空间或者索引可以用短名字。程序员在读到这样的变量的时候,可以假定这个变量的值在没有几行之后的代码中就不会再用到。通常的“草稿变量”整数的时候用 i,j,k,m,n(不过我认为最好少用 i,j,因为他们作为 MATLAB 中的永久性常量表示虚数单位的。译者注),双精度数的时候常用 x,y 和 z。前缀前缀n应该用在作为数值对象的申明的时候应该用在作为数值对象的申明的时候 例如:n

16、Files,nSegments MATLAB 一个附加的特别之处在于用 m 来表明行数(来源于 matrix 符号),例如变量名:mRows 应该遵循的一个有关复数变量的惯例应该遵循的一个有关复数变量的惯例(复数变量的惯例)(复数变量的惯例)此处的复数应该是指包含多个个体的变量,相对于单数(singular)而言译者,一个实用的建议是将所有变量名要么为单数形式,要么为复数形式。两个变量只是最后相差一个字母 s 加以区别的情况应该避免。一个可以接收的选择是对于复数利用后缀 rray。例如:point,pointArray(前者为单数,后者为复数)6 只代表单个实体数据的变量可以加以只代表单个实体

17、数据的变量可以加以后缀后缀No或者是或者是前缀前缀i 符号 No 来自于数学在表明实体数据的时候的建立规则。例如:tableNo,empolyeeNo 前缀 i 使得变量命令可以循环进行。例如变量名:iTable,iEmployee 循环变量应该以循环变量应该以i、j k 前缀前缀、该符号来源于数学在表明一个循环的时候的变量建立规则。例如:for iFile=1:nFiles end 注意:当应用中有复数数据的时候,应该禁用 i、j,因为他们都是作为虚数单位使用。对于嵌套循环嵌套循环,循环变量应该以字母表的顺序字母表的顺序。对于嵌套循环,循环变量应该命名为有帮助意思的变量名。例如:for iF

18、ile=1:nFiles for jPosition=1:nPositions end end 7 否定式的布尔变量命名是应该避免否定式的布尔变量命名是应该避免(避免(避免 如如isNotFound的命名)的命名)当采用否定式的布尔变量命名法时,如果采用逻辑运算取非的操作符号对变量进行链接运算的时候,将出现双重否定的情况。例如,用isNotFound 没有采用 isFound 直观。因此避免使用 类似于 isNotFound 这样的变量名。缩写形式,即使是通常的大写缩写,也应该于小写字母混合使用缩写形式,即使是通常的大写缩写,也应该于小写字母混合使用 全部使用大写字母作为基本的变量名与上面给出

19、的命名规则相冲突。这种类型的变量只有被命名为类似于 dVD,hTML 等形式的变量名,很显然这将使得其不具有可读性。当这样的变量名与其他的相联合的时候,其可读性严重降低;下面的单词的缩写很难看出他们的本来代表的意思了。采用:html,isUsaSpecific,checkTiffFromat()避免使用:hTML,isUSASpecific,checkTIFFFormat()避免使用一个关键字或者特殊意义的字作为变量名避免使用一个关键字或者特殊意义的字作为变量名(避免使用关键字作变量名)避免使用关键字作变量名)返回目录 当它的保留字或者内建的特殊值被重新定义的时候,MATLAB 会给出一个模糊

20、的出错信息或者是奇怪的结果。保留字在命令关键字中列出,特殊值在文档中列出了的。81.2、常数、常数 常数(包括全局变量)用常数(包括全局变量)用大写字母大写字母,下划线分割单词下划线分割单词(常数的特点常数的特点)这个规则在 C+开发团体中是非常普遍的。尽管 TMW 的代码中可能会出现一下小写字母命名常数的情况,例如:pi,这种内建常数事实上是函数。示例:MAX_ITERATIONS,COLOR_RED 参数可以以某些通用类型名作为前缀参数可以以某些通用类型名作为前缀(通用类型名作为前缀)通用类型名作为前缀)这样命名的常数给出了个附加信息,指明它们属于哪类以及他们代表的意义。如:COLOR_R

21、ED,COLOR_GREEN,COLOR_BLUE 1.3、结构体、结构体 结构体的命名应该以一个大写字母开头结构体的命名应该以一个大写字母开头 这与C+实际编程规范一致的,有助于区分结构体与普通变量。结构体的命名应该是暗示性的(结构体的命名应该是暗示性的(implicit),并且不需要包括字段名(),并且不需要包括字段名(fieldname)例如下面例子给出的重复是多余的。例:应采用 Segment.length 避免用 Segment.SegmentLength 91.3、函数(、函数(函数名应该说明他们的用途函数名应该说明他们的用途)函数名应该采用小写字母函数名应该采用小写字母 getn

22、ame(.),),computetotalwidth()()将函数名与它的 m 文件名保存为相同的是头脑清晰的做法。采用小写字母可以避免混合系统操作时候潜在的文件名问题。示例:getname(.),computetotalwidth()还有另外两种普遍使用的函数名命名规则。一些人喜欢用下划线在函数名中增加其可读性,另外一些人则根据上面提到的变量的命名规则对函数进行命名。函数名应该是具有意义的函数名应该是具有意义的(加强可读性加强可读性)存在一种不好的 MATLAB 惯例,那就是采用短的函数名,这经常使得其名字含糊不清。这或许是因为 DOS 的 8 个字母的命名规则的限制造成的影响。这种考虑担忧

23、是没有必要的了,为了增加其可读性,这种习惯也应该避免。例如:采用:computetotalwidth()避免:compwid()但是对于那些在数学中广泛使用的缩写或者首字母缩写的情况是个例外。譬如:max(),gcd()等 具有这种短的函数名的函数应该在最开始的注释的地方有完整的整个单词使得其意义清楚并且支持 lookfor 命令的查询搜索。10 单输出变量的函数可以单输出变量的函数可以根据输出参数命名根据输出参数命名(mean(.),),standarderror(.))这在 TMW 的代码中也是经常采用的,譬如:mean(.),standarderror(.)等 没有输出变量或者没有输出变

24、量或者返回值为句柄返回值为句柄的函数应该根据其的函数应该根据其实现的功能命名实现的功能命名 这种规则可以增强可读性,使得很清楚函数应该(或者不应该)干什么。这就使得代码很简洁明了并且易于理解其功能。示例:plot(.)前缀前缀get/set 应该作为访问对象或者属性的应该作为访问对象或者属性的保留前缀保留前缀 这一条在 TMW 与 C+以及 Java 开发实际中经常使用。一个合理的例外是用 set 作为逻辑置位的操作。示例:getobj(.);setappdata(.)前缀前缀 ompute应该用在计算某些量的函数的地方(应该用在计算某些量的函数的地方(提示有大计算量提示有大计算量)c一致应用

25、这一条规则是为了加强可读性。它给读者一条线索:这里是潜在的比较复杂的、或者比较耗时的操作。示例:computweightedaverage();computespread();11 前缀前缀find可以用在那些可以用在那些具有查询功能具有查询功能的函数的地方(的函数的地方(提示查询提示查询)这使得读者能够理解得到一条线索:这里是一个查询方法,包含有少量计算。一致应用这条规则可以增强其可读性,是 get 的一个好的替换品。示例:findoldestrecord(.);findheaviestelement(.);前缀前缀initialize可以用在对象或者是概念建立的地方(可以用在对象或者是概念

26、建立的地方(提示初始化提示初始化)美语中 initialize 就是指的是英国英语中的 initialise。应该避免使用缩写形式 init。示例:initializeproblemstate()前缀前缀 is应该用在应该用在布尔函数布尔函数的命名的地方(的命名的地方(相关帮助指令应该一读相关帮助指令应该一读)这通常在 TMW 的代码以及 C+与 Java 代码中普遍使用。示例:isoverpriced();iscomplete()在某些环境下,存在少量的替代它的前缀,包括 has,can 以及 should 等前缀。补足型(补足型(complement)名称应该用在补足型()名称应该用在补足

27、型(complement)操作的地方)操作的地方 下面通过一个小的归纳减少一个一个说明的复杂性。示例:get/set,add/remove,create/destroy,start/stop,insert/delete,12increment/decrement,old/new,begin/end,first/last,up/down,min/max,next/previous,open/close,show/hide,suspend/resume,等 避免无意识地覆盖(避免无意识地覆盖(shadowing)()(勿重复命名,否则有不可预期的错误勿重复命名,否则有不可预期的错误)通常,函数的命

28、名应该是唯一的(unique)。覆盖(shadowing)(两个或者多个函数具有相同的函数名)会增加不可预测的行为或者错误。可以通过 which all 或者是 exist 来检查文件名重复的情况。1.4、概要、概要 命名多维变量与常量应该命名多维变量与常量应该具有单位后缀具有单位后缀 只采用单一的单位集合是一个很不错的想法,但是通常在程序的完整实现很少见的。增加单位后缀可以帮助避免必然的混淆。示例:incidentAngleRadians 命名中应该命名中应该避免缩写(尽可能完整一些,可读性)避免缩写(尽可能完整一些,可读性)利用完整的单词命名可以减少含糊,有利于使得代码自成为文档(self

29、-documenting)。采用:computearrivaltime()避免:comparr()特殊领域的常用语的简写或者首字母缩写形式更容易自然地被理解,因此他们应该保持缩写形式。甚至在他们第一次出现的时候的定义注 13释的时候都是允许的。示例:html,cpu,cm 考虑使得名字可以拼读考虑使得名字可以拼读 在命名的时候应该至少考虑易于拼读与记忆。所有的命名都应该以英语的形式写出所有的命名都应该以英语的形式写出 MATLAB 是以英语发布的,英语是国际研发交流中最适合的语言。2、文件与程序结构、文件与程序结构 将代码结构化,不只是在文件的内部,也包括在文件之间,都能够使得程序更易于理解。

30、有思想的(thoughtful)程序结构块分割和条理化可以增加代码的质量。模块化模块化 编写一个大程序的最好的方法是将它以好的设计分化为小块(通常采用函数的方式)。这种方式通过减少为了理解代码的作用而必须阅读的代码数量使得程序的可读性、易于理解性和可测试性得到了增强。超过编辑器两屏幕的代码都应该考虑进行分割。并且设计规 划很好的函数也使得它在其他的应用中可用性增强了。14 确保交互过程清晰确保交互过程清晰 函数通过输入输出参数以及全局变量与其他代码交互通信。使用参数几乎总是 分割(分割(partitioning)()(一个函数做一件事一个函数做一件事)所有的子函数和所有的函数都应该只把一件事情

31、做好。每个函数应该隐藏(hide)一些东西。利用现有的函数(利用现有的函数(发挥发挥Matlab的优势的优势)开发一个有正确功能的、可读的、合理灵活性的函数在一项有重大意义的任务。或许寻找一个现成的提供了要求的部分、甚至全部功能的函数应该更快也更具有正确性。任何在多个任何在多个m文件中出现的代码块都应该考虑用函数的形式封装起来(文件中出现的代码块都应该考虑用函数的形式封装起来(多次重复代码考虑函数封装多次重复代码考虑函数封装)如果代码只在一个文件中出现,那么修改变换起来就会容易得多。“改变是不可避免的,除非自动售货机。”子函数子函数 只被另外一个函数调用的函数应该作为一个子函数写在同一个文件中

32、。这使得代码更加利于理解与维护。15 测试脚本(测试脚本(保证每一底层程序的可靠性保证每一底层程序的可靠性)为每一个函数写一个测试脚本。这样可以提高初期版本的质量和改进版本的可靠性。要注意的是,任何函数如果不易于测试的话就可以不易于编写的。Boris Beizer 讲到:“一个好的反 bug 人员知道,设计测试案例比实际的测试需要更多的行动。”3、输入输出、输入输出 3.1、编写输入、编写输入/输出模块输出模块 输出要求可以无需特别注意就可以根据变化而改变,输入的格式与内容根据变化的时候经常很混乱。找到处理输出的地方进行改善,提高其可维护性。避免将输入/输出部分的代码与计算功能的代码混淆在一起

33、,单个函数的预处理的时候除外。各种功能混合的函数的可再用性一遍很小。3.2、格式化输出使得其易于利用、格式化输出使得其易于利用 如果输出很大可能是人工阅读,那么就让输出采用易于越多的描述性的方式。如果输出更多的可能是通过其他软件调用而不是人,那么应该使得输出易于解析。如果这以上两种情况都很重要,将输出表达成易于解析的格式,并编写一个格式化输出的函数用来产生一个人工可读的输出版本。164、基本语句、基本语句 4.1、变量与常数、变量与常数 变量不应该重复使用变量不应该重复使用(赋予为不同意义),除非因为内存限制的需要(赋予为不同意义),除非因为内存限制的需要 通过确保所有的概念都只有唯一的意义可

34、以加强代码的可读性,以及通过消除误解的定义可以减少错误的可能。同种类型的相近的变量可以在同一个语句中定义同种类型的相近的变量可以在同一个语句中定义 不相近的变量应该不要在同一个语句中定义不相近的变量应该不要在同一个语句中定义 通过变量分组可以增强其可读性。示例:persistent x,y,z global REVENUE_JANUARY,REVENUE_FEBRUARY 注意在文件开始部分的注释中注意在文件开始部分的注释中为重要变量编写文档为重要变量编写文档 在其他的编程语言中,在变量申明的地方为他们编写文档是一种标准话的操作。既然 MATLAB 不需要变量申明,这种信息就可以在注释中提供。

35、示例:pointArray Points are in rows with coordinates in columns.注意在语句注意在语句行注释的最后为常数编写文档行注释的最后为常数编写文档 这对参数有关合理性、应用和约束等附加信息。17示例:THRESHOLD=10;Maximum noise level found by experiment。4.2、全局变量、全局变量 应该尽量少地使用全局变量应该尽量少地使用全局变量 参数传递在代码清晰性与可维护性方面都比常用全局变量要好。在某些应用 global 变量的地方可以被 persisitent 和 getappdata 所代替。应该尽量少

36、用全局常量应该尽量少用全局常量 利用 m 文件或者是 mat 文件,这样就可以使得很清楚,常数在什么地方定义的,避免无意识地重复定义。如果文件的访问接口是不令人满意的,那么可以考虑采用全局常数的结构的形式。4.3、循环语句、循环语句 循环变量应该在循环开始前立即被赋值循环变量应该在循环开始前立即被赋值 这可以提高循环的速度,有助于防止循环没有执行所有的可能索引而产生的虚假值。示例:result=zeros(nEntries,1);for index=1:nEntries result(index)=foo(index);end 18 在循环中应该尽量少用 在循环中应该尽量少用 break 与

37、与 continue 这些结构可以与 goto 相比较,只有当他们可以证明用这些结构可以比他们相应的结构化部分有更好的可读性的时候,才可以使用。在嵌套式循环的时候应该在在嵌套式循环的时候应该在end行加上注释行加上注释 在长的嵌套循环的end命令行添加注释可以有助于弄明白哪些语句在那个循环体内、在此处之前已经完成了哪些功能。4.4、条件语句、条件语句 应该避免复杂的条件表示式,而应该避免复杂的条件表示式,而采用临时逻辑变量进行替代采用临时逻辑变量进行替代 通过对表达式指定逻辑变量,使得程序更能够自为文档,使得程序结构更易于阅读与调试。示例:避免使用:if(value=lowerLimit)&(

38、values=upperLimit)&ismember(value,valueArray)end 而应该用如下的方式代替:isValid=(value=lowerLimit)&(values1),disp(Yes),end 26 关键字后面应该加上空格关键字后面应该加上空格 这种方式有助于区分关键字与函数。一个块(一个块(block)内部的一个逻辑组语句应该通过一个空白行将其分隔开)内部的一个逻辑组语句应该通过一个空白行将其分隔开 在块的逻辑单元之间加入空白行可以增强代码的可读性。块(块(blocks)之间应该用多行空白行分隔)之间应该用多行空白行分隔 一种方式是采用 3 隔空白行。采用大的间

39、隔来与块内分隔相区别,使得在文件中,块看起来非常明显。另外一种方式是采用注释符号后面跟多个诸如*或者 。通过排列成行列整齐的方式来加强可读性通过排列成行列整齐的方式来加强可读性 代码排列成行列整齐的形式可以使得切分表达式容易阅读与理解。这种排版也有助于揭示错误。示例:weithedPopulation=(doctorWeight*nDoctors)+(layerWeight*nLawyers)+(chiefWeight*nChiefs);5.5、注释、注释 注释的目的是为代码增加信息。注释的典型应用是解释用法、提供参考信息、证明结果、阐述需要的改进等。经验表明,在写代码的同时 27就加上注释比

40、后来再补充注释要好。注释不能够改变写得很糟糕的代码效果注释不能够改变写得很糟糕的代码效果 注释不能够弥补因为代码命名不当、没有清晰的逻辑结构等造成的缺陷。存在这样缺陷的代码应该重写。Steve MaConnell 说道:“提高代码质量,然后再增加文档以进一步使得其清晰。”注释文字应该简洁易读注释文字应该简洁易读 一个糟糕的或者是无用的注释反而会影响读者的正常理解。N.Schryer 提到:“如果代码与注释不一致,那么或许两者都是错误的。”一个通常更重要的是注释应该讲的是“为什么”(Why)和“怎么做”(how),而不是“是什么”(what)。函数头部的注释应该支持利用函数头部的注释应该支持利用

41、help 与与lookfor查询查询 help 命令打印出文件开题的第一块注释行。lookfor 命令搜寻路径上的所有 m 文件的第一个注释行,尽量在这一行中包含可能的搜索关键字。函数头部的注释应该讨论对输入参数的特殊要求等函数头部的注释应该讨论对输入参数的特殊要求等 使用者通常需要知道输入是否有特殊的单位要求或者矩阵类型要求 示例:%ejectionFraction must be between 0 and 1,not a percentage.%elepsedTimeSceconds must be one dimensional.28 函数头的注释应该描述其任何副作用(函数头的注释应该

42、描述其任何副作用(side effects)副作用是指函数的行为而不是指输出参数的指定。一个常见的例子是图的产生,在头说明中描述其副作用以便他们可以在用 help 指令的打印输出的时候是可见的。通常情况下,函数头注释的最后一句应该是重申函数语句行通常情况下,函数头注释的最后一句应该是重申函数语句行 这可以让用户在一眼扫过 help 指令的打印输出时可以发现函数的输入输出参数用法。在函数头注释中将函数名用大写的形式表达是一个有争议性的规则在函数头注释中将函数名用大写的形式表达是一个有争议性的规则 在 MathWorks 的开发中采用的是这样的规则,这样可以突出函数名。很多其他作者不遵循这条规则,

43、因为其缺点是通常在代码中函数名是小写字母。避免在函数头说明的避免在函数头说明的help 打印输出中的混乱打印输出中的混乱 在函数文件开头的附近通常包括版权以及修改日期等信息。在文件头说明和这些信息说明之间应该加入一个空白行,以避免在用 help 指令的时候显示出来。所有的注释语句应该用英语写作所有的注释语句应该用英语写作 在国际环境中,英语是最提倡使用的语言。295.5、文档、文档 文档规范化文档规范化 作为有用的文档应该包含一个对如下内容的可读性的描述:代码打算干什么(要求),它是如何工作的(设计),它依赖于什其他什么函数以及怎么被其他代码调用(接口),以及它是如何测试的等。对于额外的考虑,

44、文档可以包含解决方案的选择性的讨论以及扩展与维护的建议。Dick Brandon 讲到:“Documentation is like sex;when its good,its very,very good,and when its bad,its better than nothing.”首先考虑书写文档首先考虑书写文档 一些程序员相信的方法是:“代码第一,回答问题是以后的事情。”而通过经验,我们绝大多数人知道先开发设计然后再实现可以导致更加满意的结果。如果将测试与文档留在最后,那么开发项目几乎不能够按期完成的。首先书写文档可以确保其按时完成甚至可能减少开发时间。修改修改 一个专业的对代码修

45、改进行管理和写文档的方法是采用源程序控制工具。对于很简单的工程,在函数文件的注释中加入修改历史比什么都 30不做要好。示例:24 November 1971,D.B.Cooper,exit conditions modified.参考文献参考文献 The Practice of Programming,Brian Kemighan and Rob Pike The Pragmatic Programmer,Andrew Hunt,David Thomas and Ward Cunningham Java Programming Style Guidelines,Geotechnical Software Services Code Complete,Steve McConnelMicrosoft Press CCoding Standard,Todd Hoff 由于自己的文字组织能力有限,很多地方都采用了直译的形式,另外有些专业的术语 自己也不确定到底该如何翻译,因此错误之处在所难免,欢迎批评指正。Genial USTC 2004-4-25 31

展开阅读全文
相关资源
相关搜索

当前位置:首页 > 技术资料 > 其他杂项

本站为文档C TO C交易模式,本站只提供存储空间、用户上传的文档直接被用户下载,本站只是中间服务平台,本站所有文档下载所得的收益归上传人(含作者)所有。本站仅对用户上传内容的表现方式做保护处理,对上载内容本身不做任何修改或编辑。若文档所含内容侵犯了您的版权或隐私,请立即通知得利文库网,我们立即给予删除!客服QQ:136780468 微信:18945177775 电话:18904686070

工信部备案号:黑ICP备15003705号-8 |  经营许可证:黑B2-20190332号 |   黑公网安备:91230400333293403D

© 2020-2023 www.deliwenku.com 得利文库. All Rights Reserved 黑龙江转换宝科技有限公司 

黑龙江省互联网违法和不良信息举报
举报电话:0468-3380021 邮箱:hgswwxb@163.com