注释可在程序中用来说明代码功能_如何才能写出高质量java代码,这篇文章让你轻松搞定...

0540f086ff211c832a01e4299a7c103f.png
一,命名风格
  • 1,代码中的命名均不能以下划线或美元符号开始,也不能以下划线或美元符号结束。
  • 2,代码中的命名严禁使用拼音与英文混合的方式,更不允许直接使用中文的方式。
  • 3,类名、方法名、参数名、成员变量、局部变量都统一使UpperCamelCase 风格,必须遵从驼峰形式。
  • 4,常量命名全部大写,单词间用下划线隔开,力求语义表达完整清楚,不要嫌名字长。
  • 5,抽象类命名使用 Abstract 或 Base 开头;异常类命名使用 Exception 结尾 。
  • 6,接口的请求参数的bean,以Req结尾,接口的响应的bean,以Resp结尾.
  • 7,包名统一使用小写,点分隔符之间有且仅有一个自然语义的英语单词。包名统一使用单数形式。
  • 8,杜绝完全不规范的缩写,避免望文不知义。
  • 9,为了达到代码自解释的目标,任何自定义编程元素在命名时,使用尽量完整的单词 组合来表达其意。
  • 10,如果模块、接口、类、方法使用了设计模式,在命名时体现出具体模式。
  • 11,接口类中的方法和属性不要加任何修饰符号(public 也不要加),保持代码的简洁 性,并加上有效的 Javadoc 注释。
二,常量定义
  • 1,不允许任何魔法值(即未经定义的常量)直接出现在代码中 。
  • 2,long 或者 Long 初始赋值时,使用大写的 L,不能是小写的 l,小写容易跟数字 1 混 淆,造成误解。
  • 3,不要使用一个常量类维护所有常量,按常量功能进行归类,分开维护(看bean的使用范围,不要全部都写在CoreData里面)。
三,OOP规约
  • 1,避免通过一个类的对象引用访问此类的静态变量或静态方法,无谓增加编译器解析成本,直接用类名来访问即可。
  • 2,所有的覆写方法,必须加@Override 注解 。
  • 3,相同参数类型,相同业务含义,才可以使用 Java 的可变参数,避免使用 Object。
  • 4,外部正在调用或者二方库依赖的接口,不允许修改方法签名,避免对接口调用方产生 影响。接口过时必须加@Deprecated 注解,并清晰地说明采用的新接口或者新服务是什么。
  • 5,不能使用过时的类或方法。
  • 6,Object 的 equals 方法容易抛空指针异常,统一使用StringUtils.equals()方法。
  • 7,所有的相同类型的包装类对象之间值的比较,全部使用 equals 方法比较。
  • 8,构造方法里面禁止加入任何业务逻辑,如果有初始化逻辑,请放在 init 方法中。
  • 9,当一个类有多个构造方法,或者多个同名方法,这些方法应该按顺序放置在一起, 便于阅读。
  • 10,类内方法定义顺序依次是:公有方法或保护方法 > 私有方法 > getter/setter 方法。
  • 11,循环体内,字符串的连接方式,使用 StringBuilder 的 append 方法进行扩展 。
  • 12,类成员与方法访问控制从严。
四,集合处理
  • 1.不要在 foreach 循环里进行元素的 remove/add 操作 。
  • 2.在 JDK7 版本及以上,Comparator 要满足如下三个条件:

2.1 x,y的比较结果和y,x的比较结果相反
2.2 x=y,则x,z比较结果和y,z比较结果相同。
2.3 x>y,y>z,则x>z。

  • 3.使用 entrySet 遍历 Map 类集合 KV,而不是 keySet 方式进行遍历。
五,并发处理
  • 1,获取单例对象需要保证线程安全,其中的方法也要保证线程安全。
  • 2,线程资源必须通过线程池提供,不允许在应用中自行显式创建线程。
  • 3,SimpleDateFormat 是线程不安全的类,一般不要定义为static变量,如果定义为 static,必须加锁,或者使用 DateUtils 工具类。
  • 4,避免 Random 实例被多线程使用,虽然共享该实例是线程安全的,但会因竞争同一 seed 导致的性能下降。
  • 5,在并发场景下,通过双重检查锁(double-checked locking)实现延迟初始化的优化问题隐患。
六,控制语句
  • 1,在一个 switch 块内,每个 case 要么通过 break/return 等来终止,要么注释说明程 序将继续执行到哪一个 case 为止;在一个 switch 块内,都必须包含一个 default 语句并且 放在最后,即使它什么代码也没有。
  • 2,在 if/else/for/while/do 语句中必须使用大括号。即使只有一行代码。
  • 3,表达异常的分支时,少用 if-else 方式 ,可使用卫语句。
  • 4,循环体中的语句要考量性能,以下操作尽量移至循环体外处理,如定义对象、变量、 获取数据库连接,进行不必要的 try-catch 操作(这个 try-catch 是否可以移至循环体外)。
七,注释规约
  • 1,类、类属性、类方法的注释必须使用 Javadoc 规范,使用/*内容/格式,不得使用 // xxx方式。
  • 2,所有的抽象方法(包括接口中的方法)必须要用 Javadoc 注释、除了返回值、参数、 异常说明外,还必须指出该方法做什么事情,实现什么功能。
  • 3,方法内部单行注释,在被注释语句上方另起一行,使用//注释。方法内部多行注释 ,使用/* */注释,注意与代码对齐。
  • 4,代码修改的同时,注释也要进行相应的修改,尤其是参数、返回值、异常、核心逻辑 等的修改。
  • 5,对于注释的要求:第一、能够准确反应设计思想和代码逻辑;第二、能够描述业务含 义,使别的程序员能够迅速了解到代码背后的信息。完全没有注释的大段代码对于阅读者形同 天书,注释是给自己看的,即使隔很长时间,也能清晰理解当时的思路;注释也是给继任者看 的,使其能够快速接替自己的工作。

我是一名从事多年开发的java老程序猿员,目前辞职在做自己的java私人订制课程,今年年初我花了一个月整理了一份最适合2019年学习的java学习干货资料,从最基础的javase到spring各种框架都有整理,送给每一位java小伙伴,想要获取的可以关注我的头条号并在后台私信我:02,即可免费获取。

作者:JasonWangUp

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值