个人习惯常用规范

1、基础代码规范:

参考阿里巴巴代码规范Sonarlint复杂度分析,请自行在IDEA中添加相应插件进行初步代码审核。
若有与公司规范冲突的,以公司规定为准。

1.1 注释规范:

注意!任何位置(属性字段周围和方法中)与文件(java\yml\sql\properties)都不可添加行尾注释。

1.1.1 注释头参考模板:(中文替换成相应的文字即可)

一、文件注释模板

修改位置为:File > Settings > Editor > File and Code Templates
 /**
  * Description: ${description}
  *
  * @author 你的名字
  * @since ${YEAR}-${MONTH}-${DAY}
  * ·    Email: 你的邮箱@QQ.COM
  * ·© Copyright 凌动科技 Corporation
  * ·      All Rights Reserved.
  */

二、方法注释模板-参考文档

修改位置为:File > Settings > Editor > Live Templates
/**
 * Description: $description$
 *
 * @author 你的名字
 * @since $date$ $time$ $param$ $return$
 */

参数获取:

groovyScript("
    if(\"${_1}\".length() == 2) {
         return '';
    } else {
        def result='';
        def params=\"${_1}\".replaceAll('[\\\\[|\\\\]|\\\\s]', '').split(',').toList();
        for(i = 0; i < params.size(); i++) {
            result+='\\n' + ' * @param ' + params[i]
        };
        return result;
    }
", methodParameters());

返回值获取:

groovyScript("
    def returnType = \"${_1}\";  
    def result = '\\n * @return ' + returnType;
    if(returnType == \"void\") {
        return '';
    };
    return result;
", methodReturnType());

1.1.2 字段注释使用/**注释,例如:

示例 规范
/**
* 用户名
*/
// 用户名

1.2 代码规范:

代码思维尽量向领域驱动模式靠近。多使用设计模式优化代码结构,如:构建者(Builder)模式

基本模块划分:
    |-enums  枚举属性值,一般为业务控制常量存储。
    |-vo  (Value Object)值对象。主要体现在视图的对象,对于一个WEB页面将整个页面的属性封装成一个对象。然后用一个VO对象在控制层与视图层进行传输交换。
    |-bo  (Business Object)业务对象,将业务逻辑封装成一个对象。可以理解为 PO 的组合
    |-po  (Persistant Object)持久对象。一个POJO持久化以后就是PO。
    |-dto  (Data Transfer Object)数据传输对象。经过处理后的PO,可能增加或者减少PO的属性。
    |-dao  数据层
    |-manager  为复杂业务,与Dao,Feign,第三方接口配合
    |-service  接口层

命名的基本原则

(1) 标识符的命名要清晰、明了,有明确含义,同时使用完整的单词或大家基本可以理解的缩写,
    避免使人产生误解——尽量采用采用英文单词或全部中文全拼表示,若出现英文单词和中文混合定义时,使用连字符“_”将英文与中文割开。
    较短的单词可通过去掉“元音”形成缩写;较长的单词可取单词的头几个字母形成缩写;一些单词有大家公认的缩写。
    例如:temp->tmp、flag->标志寄存器、statistic->stat、increment->inc、message->msg等缩写能够被大家基本认可。

(2) 命名中若使用特殊约定或缩写,则要有注释说明。应该在源文件的开始之处,对文件中所使用的缩写或约定,特别是特殊的缩写,进行必要的注释说明。

(3) 自己特有的命名风格,要自始至终保持一致,不可来回变化。个人的命名风格,在符合所在项目组或产品组的命名规则的前提下,才可使用。
    (即命名规则中没有规定到的地方才可有个人命名风格)。

(4) 对于变量命名,禁止取单个字符(如i 、j 、k… ),建议除了要有具体含义外,还能表明其变量类型、数据类型等,但i 、j 、k 作局部循环变量是允许的。
    变量,尤其是局部变量,如果用单个字符表示,很容易敲错(如i写成j),而编译时又检查不出来,有可能为了这个小小的错误而花费大量的查错时间。

(5) 除非必要,不要用数字或较奇怪的字符来定义标识符。

(6) 命名规范必须与所使用的系统风格保持一致,并在同一项目中统一。

(7) 在同一软件产品内,应规划好接口部分标识符(变量、结构、函数及常量)的命名,防止编译、链接时产生冲突。
    对接口部分的标识符应该有更严格限制,防止冲突。如可规定接口部分的变量与常量之前加上“模块”标识等。

(8) 用正确的反义词组命名具有互斥意义的变量或相反作的函数等。

(9) 所有命名必须遵循单词词组规范。例如:username为一个单词,最好不要使用userName这类样式。

下面是一些在软件中常用的反义词组。

add / remove begin / end create / destroy
insert / delete first / last get / release
increment / decrement put / get up / down
add / delete lock / unlock open / close
min / max old / new start / stop
next / previous source / target show / hide
send / receive source / destination cut / paste
示例:
intminSum;
intmaxSum;
intaddUser;
intdeleteUser;

规范要求

一、 Java类:
  1. 注入方式统一使用构造器注入。

  2. 大类尽量按模型以及功能拆分。(类中超过二十个子方法或超过800行以上)
   例如:SchoolAddService, SchoolDeleteService 
      \ ClassAddService,ClassDeleteService等。

  3. 提交代码时及时去除无用类,以及类中的无用引用,无用方法。

  4. 类中格式化代码时,统一使用IDEA默认格式化方法。

  5. 实现序列化接口的类统一使用IDEA自动生成序列化字段。设置位置为:
   File > Settings > Editor > Inspections >
       (JVM languages/Java) > Serializable class without 'serialVersionUID'

  6. ctrl层中类上的Mapping需要确定请求前置连接可出现多次'/'且最后不可为'/',方法上的Mapping只可出现一次'/',并且符合驼峰命名。
   例如:类上注解为 @RequestMapping(value = "/service/test")
   方法上的注解统一使用已区分的 @PostMapping(value = "/list") 或 @GetMapping(value = "/getById")

  7. 类名中如有LED,IOS等专有名称,最好使用下划线加大驼峰命名方式。例如:IOS_DeviceReportBo

二、 Java方法:
  1. 方法中代码行数不得超过80行,方法名称与注释简洁明了。

  2. 方法参数五个及以上使用对应实体类类型接收,方法参数需要在注释中写明作用。

  3. 方法中需要添加日志的遵循 log.XXX(类名::方法名::说明 [-> param = {}] ) 格式。 (注:中括号中为可选)

  4. 方法中尽可能逻辑简单,如有复杂逻辑,将逻辑拆分为简单逻辑后重新在新方法中组合。

  5. Lambde表达式中只应有简单的处理逻辑,不可进行嵌套。

  6. 链式编程最好不要超过5次以上,并且所有链式方法遵循最简原则,只调用,
   少处理且不显示处理复杂逻辑,如有复杂逻辑则封装方法后再进行调用。

三、 其他:
  1. 所有自定义属性必须在YML文件中定义,如无法使用,再在相应的配置文件类型中修改。

  2. 自定义变量如跟其他平台无关,则统一放在YML文件中xxxCollection字段下。
     YML中的变量名称规范为(驼峰)格式,例如:serialVersionId。
     YML中的变量值若有单词则规范为驼峰命名格式,例如:serialVersionId。
     YML中的变量值不管事单词还是数字都不需要加引号。
     整体参考:
         xxxCollection:
           serialVersionId: 1

2、数据库规范:

2.1数据库建表为下划线小写命名方式,遵循单词词组规范。

例如:id, username, sequence_id等。

示例 规范
username
user_name

2.2除中间表以外的新建数据表必须包含以下五个字段:

created_id       varchar(32) default '-1'              null comment '创建人 创建人ID',
created_time     timestamp   default CURRENT_TIMESTAMP null comment '创建时间;创建时间',
updated_id       varchar(32) default '-1'              null comment '更新人;最后更新人ID',
updated_time     timestamp   default CURRENT_TIMESTAMP null comment '更新时间 最后更新时间',
is_deleted       tinyint     default 0                 not null comment '是否删除 是否删除0否;1是'
最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
平台声明:文章内容(如有图片或视频亦包括在内)由作者上传并发布,文章内容仅代表作者本人观点,简书系信息发布平台,仅提供信息存储服务。

推荐阅读更多精彩内容