《Code Complete》ch.7 高质量的子程序
WHAT?
子程序(routines)是为实现一个特定目的而编写的可被调用的方法或过程。在C++中是函数(function),在Java中是方法(method),在VB中是函数过程(function procedure)或子过程(sub procedure)。
WHY?
- 降低复杂度
- 引入中间、易懂的抽象
- 避免代码重复
- 支持继承、重写
- 隐藏实现细节
- 提高可移植性
- 改善性能(对明确的子程序进行优化)
HOW?
- 内聚性(cohesion):是指子程序中各种操作之间联系的紧密程度
- 编程的目标是让每一个子程序只完成一件事情
- 内聚性的几个层次,由高到低排列
- 功能内聚(functional cohesion):最强、最好的内聚,只完成一件事情
- 顺序内聚(sequential cohesion):子程序做了至少两件事情,且这两件事情有分先后顺序
- 通信内聚(communicational cohesion):子程序做了至少两件事情,它们使用了同样的数据
- 临时内聚(temporal cohesion):将一系列操作放到一起执行,如startUp()、shutDown(),应该由这些程序去调动其它子程序,而不是把实现都写在这些程序中
- bad:过程内聚(procedural cohesion):子程序中操作必须按照特定顺序进行
- bad:逻辑内聚(logical cohesion):依靠输入参数的标识位来决定执行哪一段逻辑
- bad:巧合内聚(coincidental cohesion):子程序中各个操作没有关联,一团乱麻
- 好的子程序名字
- 描述子程序所做的所有事情
- 避免使用无意义的、含混不清的动词
- bad:handleCalculation
- 不要仅通过数字形成不同的子程序名字
- bad:test1、test2
- 函数命名:对返回值有所描述
- 过程命名:动宾短语
- 如果子程序的名字很糟糕,但却正确滴描述了子程序的功能——到了考虑修改子程序的时候了
- 子程序不要超过200行
- 参数排列
- (输入、修改、输出),把状态或者出错变量放在最后
- 多个相似的子程序,使用相同的参数顺序
- 不要把参数用作工作变量
- 参数个数在7个以内
- 想清楚子程序需要的参数是一整个对象,还是仅仅为对象中几个独立的field
《Code Complete》ch.7 高质量的子程序的更多相关文章
- Code Complete
一.<代码大全>优先阅读参考顺序: 自学编程人:第07章 高质量的子程序 低年级学生:第11章 变量命名的力量 高年级学生:第08章 防御式编程 初级程序员:第18章 表驱动法 高级程序员 ...
- 重读 code complete 说说代码质量
重读code complete 说说代码质量 2014年的第一篇文章本来计划写些过去一年的总结和新年展望,但是因为还有一些事情要过一阵才能完成,所以姑且不谈这个,说说最近重读code complete ...
- 《Code Complete》ch.16 控制循环
WHAT? 反复执行的代码片段(你是第一天学编程吗) WHY? 知道如何使用及何时使用每一种循环是创建高质量软件的一个决定性因素 HOW? 检测位于循环开始/循环结尾 带退出的循环 进入循环 只从一个 ...
- 高质量C++/C编程指南(林锐)
推荐-高质量C++/C编程指南(林锐) 版本/状态 作者 参与者 起止日期 备注 V 0.9 草稿文件 林锐 2001-7-1至 2001-7-18 林锐起草 V 1.0 正式文件 林锐 20 ...
- 高质量C++[转]
高质量C++/C编程指南 文件状态 [ ] 草稿文件 [√] 正式文件 [ ] 更改正式文件 文件标识: 当前版本: 1.0 作 者: 林锐 博士 完成日期: 2001年7月24日 版 本 ...
- 高质量C++/C编程指南
http://man.chinaunix.net/develop/c&c++/c/c.htm#_Toc520634042 高质量C++/C编程指南 文件状态 [ ] 草稿文件 [√] 正式文 ...
- code complete part1
最近在看code complete,学习了一些东西,作为点滴,记录下来. 关于类: 类的接口抽象应该一致 类的接口要可编程,不要对类的使用者做过多的假设.不要出现类似于:A的输入量一定要大于多少小于多 ...
- 深入理解JavaScript系列(1):编写高质量JavaScript代码的基本要点
深入理解JavaScript系列(1):编写高质量JavaScript代码的基本要点 2011-12-28 23:00 by 汤姆大叔, 139489 阅读, 119 评论, 收藏, 编辑 才华横溢的 ...
- 编写高质量JS代码的68个有效方法(八)
[20141227]编写高质量JS代码的68个有效方法(八) *:first-child { margin-top: 0 !important; } body>*:last-child { ma ...
随机推荐
- 如何在ExtJS 6中使用Fashion美化应用程序
在Ext JS 6,一个最大的改变就是框架合并,使用一个单一的代码库,就可以为每一种设备开发各具有良好体验的最好应用程序.它还带来了一种美化应用程序的新方式. 在本文,重点是Sencha Fashio ...
- PHPCMS-首页的二级导航、轮播效果
导航栏:(header.html) <div id="menu"> <a href="{siteurl($siteid)}"><d ...
- 剑指offer系列57---整数中1出现的次数
[题目]求出1~n的整数中1出现的次数.(10进制) package com.exe11.offer; /** * [题目]求出1~n的整数中1出现的次数. * @author WGS * */ pu ...
- SVN 分支及合并的介绍和实践---命令行
写在前面 一些相关的概念和原理 进行分支开发的最佳实践 合并的分类 在 Eclipse 中进行合并操作 相关资源 写在前面 本文是由演讲整理而来的,介绍了 SVN 分支与合并的概念.流程和一些实际操作 ...
- MVC controller and View
actionresult,jsonresult redirectresult partialview, viewdata, tempdata filter viewdata,只能在当前action中有 ...
- OAF_MDS系列2_OAF页面的通过MDS多语言开发国际化(案例)
2014-06-06 Created By BaoXinjian
- 用widthStep的方法来增加某范围的像素----与imageROI对比
//用widthStep的方法来增加某范围的像素 //作者:sandy //时间:2015-10-5 #include <cv.h> #include <highgui.h> ...
- 子iframe 怎么调用 父级的JS函数
window.parent.父级函数名();
- frame动画
<?xml version="1.0" encoding="utf-8"?> <animation-list xmlns:android=&q ...
- 移动设备wap手机网页html5通过特殊链接:打电话,发短信,发邮件详细教程
如果需要在移动浏览器中实现拨打电话,调用sms发短信,发送email等功能,移动手机WEB页面(HTML5)Javascript提供的接口是一个好办法. 采用url href链接的方式,实现在Safa ...