`
- 浏览:
116543 次
- 性别:
- 来自:
济南
-
1.- DRY: Don’t repeat yourself.
DRY 是一个最简单的法则,也是最容易被理解的。但它也可能是最难被应用的(因为要做到这样,我们需要在泛型设计上做相当的努力,这并不是一件容易的事)。它意味着,当我们在两个或多个地方的时候发现一些相似的代码的时候,我们需要把他们的共性抽象出来形一个唯一的新方法,并且改变现有的地方的代码让他们以一些合适的参数调用这个新的方法。
DRY 这一法则可能是编程届中最通用的法则了,目前为止,应该没有哪个程序员对这一法则存有异议。但是,我们却能发现,一些程序在编写单元测试(unit testing)时忘记了这一法则:让我们相像一下,当你改变一个类的若干接口,如果你没有使用DRY,那么,那些通过调用一系例类的接口的unit test的程序,都需要被手动的更改。比如:如果你的unit test的诸多test cases中没有使用一个标准共有的构造类的方法,而是每个test case自己去构造类的实例,那么,当类的构造函数被改变时,你需要修改多少个test cases啊。这就是不使用DRY法则所带来的恶果。
2.- 短小的方法.
至少,我们有下面三个不错的理由要求程序员们写下短小的方法。
代码会变得更容易阅读。
代码会变得更容易重用(短方法可以减少代码间的耦合程度)
代码会变得更容易测试。
3.- 良好的命名规范
使用不错的统一的命名规范可以让你的程序变得更容易阅读和维护,当一个类,一个函数,一个变量的名字达到了那种可以“望文生义”的境界话,我们就可以少一些文档,少一些沟通。文章《编程中的命名设计那点事 》可以给你一些提示。
4.- 赋予每个类正确的职责
一个类,一个职责,这类规则可以参考一下类的SOLID 法则。但我们这里强调的不是一种单一的职责,而是一个正确的职责。如果你有一个类叫Customer,我们就不应该让这个类有sales 的方法,我们只能让这个类有和Customer有最直接关系的方法。
5.- 把代码组织起来
把代码组织起来有两具层次。
物理层组织:无论你使用什么样的目录,包(package)或名字空间(namespace)等的结构,你需要把你的类用一种标准的方法组织起来,这样可以方便查找。这是一种物理性质的代码组织。
逻辑层组织: 所谓逻辑层,主要是说,我们如果把两个不同功能的类或方法通过某种规范联系和组织起来。这里主要关注的是程序模块间的接口。这就是我们经常见到的程序模块的架构。
6.- 创建大量的单元测试
单元测试是最接近BUG的地方,也是修改BUG成本最低的地方,同样也是决定整个软件质量好坏的成败的地方。所以,只要有可能,你就应该写更多的,更好的单元测试案例,这样当你未来有相应代码改变的时候,你可以很简单知道你代码的改变是否影响了其它单元。
7.- 经常重构你的代码
软件开发是一种持续的发现的过程,从而让你的代码可以跟上最新的实际需求的变化。所以,我们要经常重构自己的代码来跟上这样的变化。当然,重构是有风险的,并不是所有的重构都是成功的,也不是我们随时都可以重构代码。下面是两个重构代码的先要条件,以避免让你引入更多的BUG,或是把本来就烂的代码变得更烂。
有大量的单元测试来测试。正如前面所说,重构需要用大量的单元测试来做保障和测试。
每次重构都不要大,用点点滴滴的小的重构来代替那种大型的重构。有太多的时候,当我们一开始计划重构2000行代码,而在3个小时后,我们就放弃这个计划并把代码恢复到原始的版本。所以,我们推荐的是,重构最好是从点点滴滴积累起来的。
8.- 程序注释是邪恶的
这一条一定是充满争议的,大多数程序员都认为程序注释是非常好的,是的,没错,程序注释在理论上是非常不错的。但是,在实际过程序当中,程序员们写出来的注释却是很糟糕的(程序员的表达能力很有问题),从而导致了程序注释成为了一切邪恶的化身,也导致了我们在阅读程序的时,大多数时候,我们都不读注释而直接读代码。所以,在这里,我们并不是鼓励不写注释,而是——如果你的注释写得不够好的话,那么,你还不如把更重要的时间花在重构一下你的代码,让你的代码更加易读,更加清楚,这比会比注释更好。
9.- 注重接口,而不是实现
这是一个最经典的规则了。接口注重的是——“What”是抽象,实现注重的是——“How”是细节。接口相当于一种合同契约,而实际的细节相当于对这种合同契约的一种运作和实现。运作是可以很灵活的,而合同契约则需要是相对需要稳定和不变的。如果,一个接口没有设计好而需要经常性的变化的话,那我们可以试想一下,这代来的后果,这绝对会是一件成本很大的事情。所以,在软件开发和调设中,接口是重中之重,而不是实现。然而我们的程序员总是注重于实现细节,所以他们局部的代码写的非常不错,但软件整体却设计得相对较差。这点需要我们多多注意。
10.- 代码审查机制
所有人都会出错,一个人出错的概率是很大的,两个人出错的概率就会小一些,人多一些,出错的概率就会越来越小。因为,人多了,就能够从不同的角度看待一个事情,虽然这样可能导致无效率的争论,但比起软件产品release后出现问题的维护成本,这点成本算是相当值得的。所以,这就是我们需要让不同的人来reivew代码,代码审查机制不但是一种发现问题的最有效的机制,同时也是一种可以知识共享的机制。当然,对于Code Review来说,下面有几个基本原则:
审查者的能力一定要大于或等于代码作者的能力,不然,代码审查就成了一种对新手的training。
而且,为了让审查者真正负责起来,而不是在敷衍审查工作,我们需要让审查者对审查过的代码负主要责任,而不是代码的作者。
另外,好的代码审查应该不是当代码完成的时候,而是在代码编写的过程中,不断地迭代代码审查。好的实践的,无论代码是否完成,代码审核需要几天一次地不断地进行。
转自:http://coolshell.cn/articles/1007.html
分享到:
Global site tag (gtag.js) - Google Analytics
相关推荐
【优质代码的十诫法则知识】是一组指导程序员编写高效、可维护和易于理解代码的原则。这些原则旨在提升代码质量,降低维护成本,并促进团队之间的协作。以下是这十诫法则的详细解读: 1. **DRY (Don't Repeat ...
动态电压恢复器(DVR)模型【2.0】在Matlab Simulink环境下的精细化仿真:全面治理电能质量问题的时序解析,动态电压恢复器(DVR)模型【2.0】在Matlab Simulink下的电能质量问题治理详解:全面应对源侧电压暂降、暂升及负载影响,历时1.1秒,动态电压恢复器(DVR)模型【2.0】 Matlab simulink 可用于治理电能质量问题:仿真总时长1.1s,DVR始终接入,具体如下: 0.1-0.2s治理源侧电压暂降; 0.3-0.4s治理源侧电压暂升; 0.5-0.6s治理电机启动引起的电压暂降; 0.7-0.8s治理变压器励磁引起的电压暂降; 0.9-1.0s治理短路故障带来的不平衡问题。 ,DVR模型; Matlab simulink; 治理电能质量问题; 仿真时长; 电压暂降; 电压暂升; 电机启动; 变压器励磁; 短路故障。,Matlab Simulink中的DVR模型2.0:电能质量问题的动态治理策略
COMSOL仿真技术研究偶极光源特性与应用,COMSOL仿真技术下的偶极光源研究与应用,comsol仿真偶极光源 ,comsol仿真; 偶极光源; 偶极子辐射; 仿真建模,Comsol仿真:偶极光源模拟与优化研究
基于FPGA的四轴运动控制IP:逻辑控制代码编写与复杂运动规划功能实现,基于FPGA的四轴运动控制IP实现:逻辑VHDL编程,支持多种运动控制算法与mcx314相当性能,基于FPGA的四轴运动控制IP。 纯逻辑vhdl代码编写。 支持回零,直线圆弧插补,小直线速度前瞻,梯形加减速,S型加减速等。 性能等同于mcx314. ,基于FPGA的四轴运动控制IP; 纯逻辑Vhdl代码编写; 回零功能; 插补功能(直线、圆弧); 速度前瞻; 梯形加减速; S型加减速; 性能等同MCX314。,基于FPGA的Vhdl四轴运动控制IP:高性能、灵活配置的S型加减速插补器
机器人控制系统及设计程序,含仿真程序、控制系统及代码。
1、以上文章可用于参考,请勿直接抄袭,学习、当作参考文献可以,主张借鉴学习 2、资源本身不含 对应项目代码,如需完整项目源码,请私信博主获取
基于博途1200 PLC与HMI的十层二部电梯控制系统仿真工程:实现集群运行与优化配置的研究实践,基于博途PLC及HMI的十层二部电梯控制系统仿真与优化实践,基于博途1200PLC+HMI十层二部电梯控制系统仿真 程序: 1、任务:PLC.人机界面控制双部电梯集群运行 2、系统说明: 系统设有上呼、下呼、内呼、手动开关门、光幕、检修、故障、满载、等模拟模式控制, 系统共享厅外召唤信号,集选控制双部电梯运行。 十层二部电梯途仿真工程配套有博途PLC程序+IO点表 +PLC接线图+主电路图+控制流程图, 附赠:设计参考文档(与程序不是配套,仅供参考)。 博途V16+HMI 可直接模拟运行 程序简洁、精炼,注释详细 ,基于博途1200PLC; HMI双部电梯控制; 电梯控制模式; 控制系统仿真; 博途V16+HMI模拟运行。,基于博途1200的十层二部电梯控制系统仿真程序
COMSOL流体仿真下的流固耦合现象:圆管内流体驱动物块移动与扇叶转动探究,COMSOL流体仿真:流固耦合下的圆管内流体驱动动态模拟——流体驱动物块移动与扇叶转动研究,comsol流体仿真 ,流固耦合,圆管内流体驱动物块的移动和 流体驱动扇叶的转动 ,comsol流体仿真;流固耦合;圆管内流体驱动物块移动;流体驱动扇叶转动,Comsol流体仿真:圆管内流固耦合与流体驱动的物块移动及扇叶转动研究
本研究探讨了大型语言模型如何通过提示工程对科学论文中的句子进行分类。我们使用两种先进的基于网络的模型,OpenAI 的 GPT-4o 和 DeepSeek R1,将句子分类为预定义的关系类别。DeepSeek R1 已在其技术报告中测试过基准数据集。然而,其在科学文本分类中的性能尚未得到充分探索。为解决这一问题,我们引入了一种专门为该任务设计的新评估方法,并整理了一个来自多个领域的清洁科学论文数据集。该数据集提供了一个比较这两个模型的平台。通过使用此数据集,我们分析了它们在分类中的有效性和一致性。
海神之光上传的视频是由对应的完整代码运行得来的,完整代码皆可运行,亲测可用,适合小白; 1、从视频里可见完整代码的内容 主函数:main.m; 调用函数:其他m文件;无需运行 运行结果效果图; 2、代码运行版本 Matlab 2019b;若运行有误,根据提示修改;若不会,私信博主; 3、运行操作步骤 步骤一:将所有文件放到Matlab的当前文件夹中; 步骤二:双击打开main.m文件; 步骤三:点击运行,等程序运行完得到结果; 4、仿真咨询 如需其他服务,可私信博主; 4.1 博客或资源的完整代码提供 4.2 期刊或参考文献复现 4.3 Matlab程序定制 4.4 科研合作
三相逆变整流并网技术:正负序分离消除负序电流,保障光伏风力发电系统电流三相对称的研究,三相逆变整流并网技术的正负序分离与负序电流消除策略在电网电压不平衡跌落中的应用——适用于光伏与风力发电系统,三相逆变 整流并网,正负序分离,在电网电压不平衡跌落 平衡跌落时,消除负序电流,维持电网电流三相对称,可用于光伏和风力发电系统 有参考文献 ,三相逆变;整流并网;正负序分离;电网电压不平衡跌落;消除负序电流;光伏和风力发电系统;参考文献,三相逆变整流并网技术:电网电压不平衡下的负序电流消除策略
题目:基于51单片机的多参数水质监测与报警系统设计 主控:AT89C51 显示:LCD1602 DS18B20温度传感器 浊度传感器(PCF8591+滑动变阻器模拟) PH传感器(ADC0832+滑动变阻器) 声光报警 led*4 功能: 1.实时检测水质温度、浊度、PH 2.实时显示相关数据 3.可以通过按键修改阈值 4.各数值不在标准范围内启动声光报警 5.ph低于下限红色小灯点亮;ph高于上限绿色小灯电亮;温度低于阈值蓝色小灯电亮;浑浊度高于阈值橙色小灯电亮
海神之光上传的视频是由对应的完整代码运行得来的,完整代码皆可运行,亲测可用,适合小白; 1、从视频里可见完整代码的内容 主函数:main.m; 调用函数:其他m文件;无需运行 运行结果效果图; 2、代码运行版本 Matlab 2019b;若运行有误,根据提示修改;若不会,私信博主; 3、运行操作步骤 步骤一:将所有文件放到Matlab的当前文件夹中; 步骤二:双击打开main.m文件; 步骤三:点击运行,等程序运行完得到结果; 4、仿真咨询 如需其他服务,可私信博主; 4.1 博客或资源的完整代码提供 4.2 期刊或参考文献复现 4.3 Matlab程序定制 4.4 科研合作
内容概要:本文档《Java网络编程教程》详细介绍了Java在网络编程中的应用,覆盖了从基础知识到高级技术的各个层面。首先讲解了网络编程的概念和Java提供的相关库如java.net和java.nio,以及基于这两个库的Socket和非阻塞I/O的编程技巧,随后深入探讨了多线程并发处理、数据流的操作及网络数据格式(JSON与XML)。接着文档讨论了实践中常用的技术,如HTTP编程、聊天室应用的开发和异常处理。此外,还介绍了Java NIO的Buffer、Channel和Selector机制及其性能优化策略,分布式系统的RPC、RESTful API、消息队列和分布式缓存等内容。最后,探讨了网络安全方面的知识,包括SSL/TLS协议、数据加密技术和防火墙配置。 适合人群:适合初学者至中级水平的Java程序员,尤其是那些想深入理解和掌握Java在网络编程中的各类应用和技术的人群。 使用场景及目标:文档旨在使开发者深入了解并熟练掌握Java在网络编程领域的应用,从而能够独立开发高可靠性的网络应用程序和服务。无论是创建简单的客户端还是复杂的服务器端程序,或是参与大规模分布式的项目都适用。 其他说
海神之光上传的视频是由对应的完整代码运行得来的,完整代码皆可运行,亲测可用,适合小白; 1、从视频里可见完整代码的内容 主函数:main.m; 调用函数:其他m文件;无需运行 运行结果效果图; 2、代码运行版本 Matlab 2019b;若运行有误,根据提示修改;若不会,私信博主; 3、运行操作步骤 步骤一:将所有文件放到Matlab的当前文件夹中; 步骤二:双击打开main.m文件; 步骤三:点击运行,等程序运行完得到结果; 4、仿真咨询 如需其他服务,可私信博主; 4.1 博客或资源的完整代码提供 4.2 期刊或参考文献复现 4.3 Matlab程序定制 4.4 科研合作
基于模型预测控制的车辆换道轨迹跟踪:五次多项式换道轨迹设计与Matlab与Carsim联合仿真研究,基于模型预测控制的车辆换道轨迹跟踪研究:五次多项式换道轨迹与Matlab-Carsim联控应用,基于模型预测控制(mpc)的车辆道,车辆轨迹跟踪,道轨迹为五次多项式,matlab与carsim联防控制 ,基于模型预测控制(MPC)的车辆换道; 车辆轨迹跟踪; 换道轨迹五次多项式; MATLAB与CARSIM联防控制,基于MPC的车辆换道控制:五次多项式轨迹跟踪与Matlab-CarSim联合仿真
MATLAB Simulink单相并网逆变器主动移频法(AFD)孤岛检测仿真系统:全面集成高效响应与智能频移的电力安全保障技术,MATLAB Simulink单相并网逆变器主动移频法(AFD)孤岛检测仿真系统:全面集成高效响应与智能频移的电力安全保障技术,MATLAB simulink单相并网逆变器主动移频法(AFD)孤岛检测仿真系统,附相关说明。 全面仿真架构:本系统集成了单相电网、逆变器、滤波模块、PI控制器、PWM信号发生器、锁相环、AFD控制器S函数以及高精度测量模块,构建了一个完整且精确的仿真环境。 先进检测技术:采用前沿的主动移频法(AFD)进行孤岛检测,该技术通过智能调整逆变器输出电流的频率参考,有效识别孤岛状态,确保电力系统的安全稳定。 高效响应与精准检测:AFD算法设计巧妙,响应速度快,检测精度高,能在第一时间发现并响应孤岛事件,有效防止潜在的安全隐患。 智能频移机制:主动移频法(AFD)的核心在于,它通过在公共点电压频率上施加一个固定偏移量作为逆变器输出电流的参考频率。 电网正常供电时,电流频率受电网频率约束保持稳定;电网失电,逆变器参考电流频率中的偏移量将驱动本地
基于直驱永磁同步技术的风力发电机MATLAB仿真模型的研究与实现,直驱永磁同步风力发电机的MATLAB仿真模型构建与应用研究,直驱永磁同步风力发电机MATLAB仿真模型 ,直驱永磁; 同步风力; 发电机; MATLAB仿真模型; 核心关键词,MATLAB仿真模型:直驱永磁同步风力发电机
1、以上文章可用于参考,请勿直接抄袭,学习、当作参考文献可以,主张借鉴学习 2、资源本身不含 对应项目代码,如需完整项目源码,请私信博主获取
基于西门子和三菱程序及组态王的自动药片装瓶机电气设计与控制系统梯形图详解,西门子和三菱PLC结合组态王的自动药片装瓶机电气设计与控制系统梯形图解析,基于西门子和三菱程序和组态王的自动药片装瓶机控制系统设计电气设计组态设计程序带解释的梯形图程序,接线图原理图图纸,io分配,组态画面 三菱的No.441 药片自动装瓶机控制系统设计自动药片装瓶机电气控制 ,西门子; 三菱程序; 组态王; 药片自动装瓶机控制系统设计; 电气设计; 组态设计; 梯形图程序; 接线图原理图图纸; IO分配; 组态画面。,西门子&三菱自动药片装瓶机控制系统的电气设计与程序解读