代码走查检查表_第1页
代码走查检查表_第2页
代码走查检查表_第3页
代码走查检查表_第4页
代码走查检查表_第5页
全文预览已结束

下载本文档

版权说明:本文档由用户提供并上传,收益归属内容提供方,若内容存在侵权,请进行举报或认领

文档简介

代码走查检查表评审日期:年 月 日评审对象作者评审人评审工作量序号检查项评审意见走查前准备1得到一份解释代码的最新的设计文档,作为代码走查的参考 2代码都已提交 ,版本统一程序结构组织1所有代码的结构清晰,具有良好的结构外观和整齐2所有的模块(函数和外部接口)定义清晰,模块分解清楚3所有的功能需求都明显的覆盖 4整个代码体系结构组合合理,分层清晰,代码之间功能划分明确5所有的接口模块化,尽量减少接口之间的耦合度,修改时尽量不影响其他代码模块 6代码体系构架对空间和速度都已经进行考虑 7数据库操作、IO操作等是否正确关闭资源。并且必须在try -catch-finally 的finally中关闭。8一个业务如果进行多次数据库更新、添加、删除是否正确添加事务。9进行逻辑与、逻辑或判断时是否使用短路与、短路或。10多处使用相同代码时,应定义唯一方法或变量以供使用。11对象是否使用工厂获取。12导入类时,如果仅使用包中的几个类,应导入具体类,而不是导入整个包。13数组声明的时候使用 int index ,而不要使用 int index。14代码实现的逻辑是否与详细设计描述的逻辑一致15检查类中是否有无效的代码或者是无用的代码。16不要使用System.out.print()以及System.err输出,需要进行日志处理17所有的文件名符合文件命名规范,见名知意18文件和模块分组清晰 19较长的语句、表达式或参数(80字符)要分成多行书写,长表达式要在低优先级操作符处划分新行,操作符放在新行之首,划分出的新行要进行适当的缩进,使排版整齐,语句可读20每个程序文件都小于2000行代码组织1数据库查询语句不要出现select * 2对需要处理的字符串定义为StringBuffer ,常量定义成静态的。3所有的变量名都小于32字符 4有返回值的方法是否正确返回。Return语句应定义在方法结尾处。5代码排版是否规范。6所有的行每行最多只有一句代码或一个表达式 7复杂的表达式具备可读性,添加注释说明,表达式结构清晰8续行缩进9括号在合适的位置 10每个顺序的小块用空行隔开11注释和代码对齐或接续在代码之后12JSP必须不能有basepath。13JSP引用js全部要有path14JSP用的标签库是否都正确引用。15JSP写的js方法必须要有注释。代码是否可读。16代码的逻辑是否有问题。17JSP页面尽量不要写过多的隐藏域。18JSP页面要注意排版、必要的注释、尽量减少使用alert(),JS和CSS除非必要就放到外部的单独文件中,在JSP中引用。19实例变量是否使用private修饰并定义getter、setter方法。20连接数据库的方法必须调用公用的方法。21异常要统一处理,异常处理方法是否符合项目组的约定22在Action中不要过多的逻辑处理代码23不要出现魔鬼数字24检查可能出现空指针异常的地方,例如一个对象可能为空,却调用它的方法或属性。25显示的文本无拼写和语法错误26所有的表达式使用了正确的操作符函数组织1所有的函数名都小于64个字符2函数高内聚 尽量只做一件事情,并做好 3函数和其他代码松耦合4所有的参数都被使用5如果一个函数有返回值,在所有的出口都有返回值 6函数使用了最少数目的return语句7函数的参数个数小于7个8使用的算法说明清楚9函数检查了输入数据的合法性 10函数异常处理清楚11函数设计尽量考虑将来的变化 12调试信息存在于代码中并容易激活 13递归定义了出口 14递归局限于一个函数 15对接口的调用必须要有判断传入的参数不能为空和传入的参数正确。数据类型与变量1数据类型存在数据类型解释 2代码避免了重新定义预先定义的数据类型 3每一个变量都初始化了 4所有的变量都有最小的活动范围5所有的全局变量都描述清楚,如全局变量的作用6所有的变量都用到了 条件判断1If/else 使用正确 2判断的次数降到最小 3Boolean表达式表示清楚 4最常用的情况最先判断,所有的情况都考虑 5 判断体足够短,以使得一次可以看清楚,不要有臃肿的逻辑判断。6嵌套层次小于3次7判断条件使用引用时,应先判断其是否为null。循环1不要出现三层以上的for循环。如有必要必须写清楚注释2循环体不为空,循环体能够一次看清楚 3循环之前做好初始化代码 4当有明确的多次循环操作,使用For循环 5当有不明确的多次循环操作,while循环被使用6代码中不存在无穷次循环 7循环的头部进行循环控制 8循环体内的循环变量起到指示作用。9所有的循环边界是否正确;10循环终止的条件清晰 11循环条件、判断条件的边界值,数组、集合下标是否越界。注释1类、方法、判断条件、循环、主要变量是否添加注释。2类名、方法名、变量名的命名是否规范。3有返回值的方法是否正确返回。Return语句应定义在方法结尾处。4源代码能够自我解释,每个人看到代码就能很快理解 5解释不过于简单,解释说明代码功能,准确描述代码意义6所有的假设和限制进行注解7长的控制体结束,进行注解 8对if和for、while等要进行必要的注释,并且方法体都要用 包起来9代码的注释不能过于简单,要清晰明了。10缺陷修改阶段,提交代码的时候必须写清楚修改的功能点和为什么要修改。总括1无用的代码、注解已经删除 2除非必要,不要在循环体内定义对象。“其他注意项1尽量减少同名的类(如java.sql.Date,java.util.Date)2不要在循环中反复定义创建变量for()String str= (new String)v.next();3可能重复执行的SQl语句尽量使用preparedStatment4浮点型要精确比较时不要使用,而如下进行Math.abs(x-0.0)Double.MIN.value*25在sql中注意敏感的单词要回避使用DB2 中id flag year month name stateOracle 中number Sybase中 count6代码与操作系统无关,不需要任

温馨提示

  • 1. 本站所有资源如无特殊说明,都需要本地电脑安装OFFICE2007和PDF阅读器。图纸软件为CAD,CAXA,PROE,UG,SolidWorks等.压缩文件请下载最新的WinRAR软件解压。
  • 2. 本站的文档不包含任何第三方提供的附件图纸等,如果需要附件,请联系上传者。文件的所有权益归上传用户所有。
  • 3. 本站RAR压缩包中若带图纸,网页内容里面会有图纸预览,若没有图纸预览就没有图纸。
  • 4. 未经权益所有人同意不得将文件中的内容挪作商业或盈利用途。
  • 5. 人人文库网仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对用户上传分享的文档内容本身不做任何修改或编辑,并不能对任何下载内容负责。
  • 6. 下载文件中如有侵权或不适当内容,请与我们联系,我们立即纠正。
  • 7. 本站不保证下载资源的准确性、安全性和完整性, 同时也不承担用户因使用这些下载资源对自己和他人造成任何形式的伤害或损失。

评论

0/150

提交评论