如何高效编码? 使用有意义的命名

简介: 编码中随处可见命名。我们给变量、函数、参数、类和包命名;我们jar文件命名。我们命名,命名,不断命名,既然有怎么多命名要做,不妨就做好它。

编码中随处可见命名。我们给变量、函数、参数、类和包命名;我们jar文件命名。我们命名,命名,不断命名,既然有怎么多命名要做,不妨就做好它。


一、名副其实

名副其实说起来很简单,但我得强调,这很严肃。选个好名字要花时间,但是后面省下来的时间要比花掉得多。


注意命名,而且一旦发现有更好的命名,就换掉旧的。这么做,读你代码的人(包括你自己)都会更开心。


变量、方法、类的命名应该告诉你,它为什么存在,它做什么事,应该怎么用。


如果名称还需要用注释来说明,那就不算名副其实了。


比如下面几个


String s = ""; //要执行的SQL

名称s什么也没说明,为什么不改成String sql = "";呢


Date d; //开始时间

开始时间完全可以叫做startTime


List<Book> list = new ArrayList<>(); //返回的图书集合

它可以叫做books,说明这是一个存book的集合。或者叫做respList,表明他是要返回的集合。


二、避免误导

我们必须避免留下掩藏代码本意的错误线索,避免使用与本意相悖的词。


别用accountList来命名一组账号,除非它真的是List类型。如果它不是一个List类型,就会引起错误的判断,所以我们用accountGroup或者直接用accounts要更好一些。


我们还要提防使用跟其他命名很相似的名称,比如selectProjectForErrorsOfStringByName和selectProjectForNormalsOfStringByName,想区分这两个得花多长时间呢,这两个名字外形太相似了。


还有就是要避免0和O混用,1和l和I混用。


三、做有意义的区分

如果我们只是为满足编译器或IDE的需求而写代码,就会制造麻烦。例如,因为同一作用域内两个变量不能重名,你可能会随手改掉其中一个的名称。有时候干脆用错误的拼写充数,甚至直接在后面加个1。


废话是另一种没意义的区分,假如你有一个ProjectInfo类,又有一个ProjectData类。那这两个虽然名称不同,意思却没什么区别。


废话都是冗余,variable一词永远不应该出现在变量名中,table一词永远不应该出现在表名中。NameString会比Name好吗,难道Name会是一个浮点数?或者说有个名为Student类,又有一个StudentObject类,区别何在?


所以说,如果缺少明确约定,customerInfo与customer没区别,theMessage与message没区别。


四、使用读得出来的名称

有一个生成日期的方法,生成格式是年月日时分秒,叫做genymdhms。很明显这读不出来,除非你按你自己的理解来读,读出来了别人也不一定知道你说的是这个方法。


五、使用可搜索的名称

名称长短应该与其作用域大小相对应,若变量或常量可能在代码中多处使用,就应该赋予其便于搜索的名称。


比如一个只有一两行代码的for循环,就可以直接使用fori


如果是在代码中多处使用的变量或常量,就应该起一个容易发现的名称。这也是为什么常量推荐使用大写用下划线分隔。比如一个表示用户名称错误的字符串,USER_INPUT_ERROR肯定要比uie更容易发现一些。


六、类名使用名词,方法名使用动词

类名和对象名应该是名词或者名词短语,比如Customer、Student、Project、StudentInfo,但是避免使用Data、Info、Detail这样的类名。


方法名应该是动词或动词短语,比如save、findUsers、deletePage等。又或者Javabean里面的getset方法。


七、每个概念对应一个词

给每个概念选一个词,比且一以贯之。用同样的风格来给每个类中的同种方法命名。


比如同一个类中查找数据的方法,find和select和get和query有什么区别。


八、别用双关语

不要把同一单词用于不同目的,同一术语用于不同概念,基本就是双关语了。


比如,在多个类中都有add方法,该方法通过连接两个原值来获得新值。如果现在要写一个新类,类中有一个方法是把单个参数添加到一个集合中,这个方法应该也叫add吗?这样是跟原来的add方法保持一致了,但实际语义却不同。应该用append或者insert之类的来命名。


九、使用解决方案领域的名称

记住,只有程序员才会读你的代码。所以,尽管使用计算机领域的术语来命名。


如果你使用问题所涉及的领域来命名,难道下一个读你代码的人要去跑去问客户每个名称的含义吗?


程序员要做太多技术性的工作,取一个技术性的名称,通常是最靠谱的做法。


如果不能使用我们熟悉的术语来给手头的工作命名,就只能采用所涉问题领域来命名了。与所涉问题领域更贴近的代码,应当使用源自问题领域的名称。


最后,取好名字最难的地方在于需要良好的描述技术和共有文化背景。与其说这是一种技术或管理问题,还不如说是一种教学问题。结果是,这个领域内的许多人都没能学会做得很好。


多数时间我们并不会刻意去记类名和方法名,使用现代IDE都可以对付这些,好让自己集中精力于把代码写的就像词语篇章。


不妨试试上面这些规则,看你的代码可读性是否会有所提升


相关文章
|
2月前
|
SQL JavaScript 前端开发
模板字符串的优点是什么?
模板字符串的这些优点使其成为现代JavaScript开发中处理字符串的首选方式,广泛应用于各种场景,如构建HTML模板、生成动态文本内容、格式化日志信息等。
|
2月前
|
JavaScript 前端开发 Java
模板字符串和普通字符串的性能差异大吗?
总体而言,模板字符串和普通字符串的性能差异并非在所有场景下都非常显著,但在一些复杂的、对性能要求较高的场景中,模板字符串可能会展现出一定的优势。不过,在实际开发中,性能并非是选择使用哪种字符串的唯一考量因素,代码的可读性、可维护性以及开发效率等同样重要。
|
8月前
|
存储 编译器 C语言
【C++】C++中规范[ 类型转换标准 ] 的四种形式
【C++】C++中规范[ 类型转换标准 ] 的四种形式
|
数据可视化 数据管理 数据处理
编码集的作用?
编码集的作用?
|
8月前
|
中间件 数据格式
中间件数据格式文本与二进制之间的转换
中间件数据格式文本与二进制之间的转换
46 2
|
8月前
再见手动编码,标准自动化编码规则来帮忙!
标准管理员小S面临数据标准编码管理的挑战:编码格式不统一、编码值不可读活相关性差,手动管理耗时易出错。Dataphin新推出“标准编码规则”功能,可以实现一次配置批量生成编码,并通过自增序列、固定字符串和所属标准集编码的组合,保证编码相关性和灵活性,同时提供了编码规则变更后的批量订正功能,大大简化管理工作。小S对此表示高度满意。
154 0
编码细节引起的思考
小编感悟:初始菜鸟的我们,在运用封装好的方法时,不仅要学习如何使用,更要学习封装的方法中还有什么东西,最后还要学习对应的方法是如何封装起来的,知识只有这样的学习才能够让自己变得更加强大。
软件工程——程序编码(程序编码总原则、5个好程序标准、源程序文档化)
当工程规模很大时,而又没有完全合适的语言,可编一个专用的语言
|
存储 SQL 编解码
base64编码底层转换规则举例解读
base64编码底层转换规则举例解读
272 0
base64编码底层转换规则举例解读
|
设计模式 JSON 运维
代码荣辱观-以运用风格为荣,以随意编码为耻
代码荣辱观-以运用风格为荣,以随意编码为耻