第一章 可读性
- 法则01:准确命名
- 法则02:设置缩进
- 法则03:保留个性
- 法则04:语法潜台词
- 法则05:补充注释
第二章 可靠性
一, 法则06:增强健壮性
二, 法则07:避免过度防御
例:if(path == NULL)//对指针的合法性进行检查
{
}
过度防御,没有必要。
- 参数的合法性由调用者保证。
- 过度防御造成大量冗余。
- 过度防御增加问题定位难度。
正确的保护方法 在可能出错的地方进行保护,做“正当防卫”。
三, 法则08:防止不确定性
例:1,使用sleep进行某种流程控制
2,动态申请内存
四, 法则09:善始善终
- 法则10:异常处理
一个系统的可靠性往往取决于其对异常处理的完备性。
- 法则11:留意编译告警
告警中往往存在潜在问题。
- 法则12:尽早暴露问题
- 法则13:规避短板
第三章 效率
一, 法则14:关注性能热点
二, 法则15:留意非热点代码
三, 法则16:采取缓存
四, 法则17:引入并发
引入并发机制是从系统框架层面提升效率的一种方案。前提:大的任务可以被分解成若干独立执行的小任务。
第四章 可维护性
一, 法则18:记录日志
日志系统是否完备直接影响软件产品维护和问题定位的难易程度。记录日志内容要适当。
二, 法则19:明确错误提示、
三, 法则20:代码看护
针对代码的某个约束条件,在程序运行时对其进行判断,约束条件不满足时,给出明确提示并终止程序。
特点:1.看护代码写在正式代码中。
2.写在程序必然会执行的流程里,最好写在程序开始运行的地方。
3.针对不可能出错的约束条件。
四, 法则21:消除冗余代码
提取公共函数
五, 法则22:掌握逻辑运算
C,C++,Java:A与B—A&&B;A或B—A||B;非A—!A。
满足:1,结合律 2,分配率 3,反演率
六, 法则23:控制函数规模
七, 法则24:控制文件规模
第五章 可扩展性
一, 法则25:正确理解面向对象设计
优先使用组合而非继承。有些场景只能使用组合。
优先使用组合的原则:把大对象分小块,把某些具体功能委托给这些模块。
二, 法则26:控制接口规模
三, 法则27:写可重用的模块
四, 法则28:写可重入的函数
五, 法则29:避免循环依赖
六, 法则30:保障平稳升级
七, 法则31:灵活注入对象
开放封闭原则:模块或函数应该对扩展开放,对修改封闭。
八, 法则32:正确运用依赖注入