个人习惯常用规范

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是'
最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 217,406评论 6 503
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 92,732评论 3 393
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 163,711评论 0 353
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 58,380评论 1 293
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 67,432评论 6 392
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 51,301评论 1 301
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 40,145评论 3 418
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 39,008评论 0 276
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 45,443评论 1 314
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 37,649评论 3 334
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 39,795评论 1 347
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 35,501评论 5 345
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 41,119评论 3 328
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 31,731评论 0 22
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 32,865评论 1 269
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 47,899评论 2 370
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 44,724评论 2 354

推荐阅读更多精彩内容