一些开发规则

Service/DAO 层方法命名规约

1. 获取单个对象的方法用 get 做前缀。

2. 获取多个对象的方法用 list 做前缀,复数结尾,如:listObjects。

3. 获取统计值的方法用 count 做前缀。

4. 插入的方法用 save/insert 做前缀。

5. 删除的方法用 remove/delete 做前缀。

6. 修改的方法用 update 做前缀。

领域模型命名规约 

1. 数据对象:xxxDO,xxx 即为数据表名。

2. 数据传输对象:xxxDTO,xxx 为业务领域相关的名称。

3. 展示对象:xxxVO,xxx 一般为网页名称。

4. POJO 是 DO/DTO/BO/VO 的统称,禁止命名成 xxxPOJO。

public static void main(String[] args) {
     // 缩进 4 个空格
     String say = "hello";
     // 运算符的左右必须有一个空格
     int flag = 0;
     // 关键词 if 与括号之间必须有一个空格,括号内的 f 与左括号,0 与右括号不需要空格
     if (flag == 0) {
         System.out.println(say);
     }
     // 左大括号前加空格且不换行;左大括号后换行
     if (flag == 1) {
         System.out.println("world");
     // 右大括号前换行,右大括号后有 else,不用换行
     } else {
         System.out.println("ok");
     // 在右大括号后直接结束,则必须换行
     }
}

单行字符数限制不超过 120 个,超出需要换行,换行时遵循如下原则:

1.第二行相对第一行缩进 4 个空格,从第三行开始,不再继续缩进,参考示例。

2.运算符与下文一起换行。

3.方法调用的点符号与下文一起换行。

4.方法调用中的多个参数需要换行时,在逗号后进行。

StringBuilder sb = new StringBuilder();
// 超过 120 个字符的情况下,换行缩进 4 个空格,并且方法前的点号一起换行
sb.append("yang").append("hao")...
 .append("chen")...
 .append("chen")...
 .append("chen");

浮点数之间的等值判断,基本数据类型不能用==来比较,包装数据类型不能用 equals 来判断。

(1) 指定一个误差范围,两个浮点数的差值在此范围之内,则认为是相等的。
    float a = 1.0F - 0.9F;
    float b = 0.9F - 0.8F;
    float diff = 1e-6F;
    if (Math.abs(a - b) < diff) {
     System.out.println("true");
    }
(2) 使用 BigDecimal 来定义值,再进行浮点数的运算操作。
    BigDecimal a = new BigDecimal("1.0");
    BigDecimal b = new BigDecimal("0.9");
    BigDecimal c = new BigDecimal("0.8");
    BigDecimal x = a.subtract(b);
    BigDecimal y = b.subtract(c);
    if (x.compareTo(y) == 0) {
      System.out.println("true");
    }

数据库字段的 bigint 必须与类属性的 Long 类型相对应。

使用索引访问用 String 的 split 方法得到的数组时,需做最后一个分隔符后有无内容 的检查,否则会有抛 IndexOutOfBoundsException 的风险。

循环体内,字符串的连接方式,使用 StringBuilder 的 append 方法进行扩展。

日期格式化时,传入 pattern 中表示年份统一使用小写的 y。

在日期格式中分清楚大写的 M 和小写的 m,大写的 H 和小写的 h 分别指代的意义。

说明:日期格式中的这两对字母表意如下:

1. 表示月份是大写的 M;

2. 表示分钟则是小写的 m;

3. 24 小时制的是大写的 H;

4. 12 小时制的则是小写的 h。

判断所有集合内部的元素是否为空,使用 isEmpty()方法,而不是 size()==0 的方式。

在使用 java.util.stream.Collectors 类的 toMap()方法转为 Map 集合时,一定要使 用含有参数类型为 BinaryOperator,参数名为 mergeFunction 的方法,否则当出现相同 key 值时会抛出 IllegalStateException 异常。

List<Pair<String, Double>> pairArrayList = new ArrayList<>(3);
pairArrayList.add(new Pair<>("version", 12.10));
pairArrayList.add(new Pair<>("version", 12.19));
pairArrayList.add(new Pair<>("version", 6.28));
Map<String, Double> map = pairArrayList.stream().collect(
// 生成的 map 集合中只有一个键值对:{version=6.28}
Collectors.toMap(Pair::getKey, Pair::getValue, (v1, v2) -> v2));

在使用 java.util.stream.Collectors 类的 toMap()方法转为 Map 集合时,一定要注 意当 value 为 null 时会抛 NPE 异常。

if (value == null || remappingFunction == null)
throw new NullPointerException();

使用集合转数组的方法,必须使用集合的 toArray(T[] array),传入的是类型完全一 致、长度为 0 的空数组。

List<String> list = new ArrayList<>(2);
list.add("guan");
list.add("bao");
String[] array = list.toArray(new String[0]);
 说明:使用 toArray 带参方法,数组空间大小的 length:
1) 等于 0,动态创建与 size 相同的数组,性能最好。
2) 大于 0 但小于 size,重新创建大小等于 size 的数组,增加 GC 负担。
3) 等于 size,在高并发情况下,数组创建完成之后,size 正在变大的情况下,负面影响与 2 相同。
4) 大于 size,空间浪费,且在 size 处插入 null 值,存在 NPE 隐患。

不要在 foreach 循环里进行元素的 remove/add 操作。remove 元素请使用 Iterator 方式,如果并发操作,需要对 Iterator 对象加锁。

List<String> list = new ArrayList<>();
list.add("1");
list.add("2");
Iterator<String> iterator = list.iterator();
while (iterator.hasNext()) {
 String item = iterator.next();
 if (删除元素的条件) {
 iterator.remove();
 }
}

利用 Set 元素唯一的特性,可以快速对一个集合进行去重操作,避免使用 List 的 contains()进行遍历去重或者判断包含操作。

资金相关的金融敏感信息,使用悲观锁策略。

除常用方法(如 getXxx/isXxx)等外,不要在条件判断中执行其它复杂的语句,将复 杂逻辑判断的结果赋值给一个有意义的布尔变量名,以提高可读性。 说明:很多 if 语句内的逻辑表达式相当复杂,与、或、取反混合运算,甚至各种方法纵深调用,理解成本 非常高。如果赋值一个非常好理解的布尔变量名字,则是件令人爽心悦目的事情。

// 伪代码如下
final boolean existed = (file.open(fileName, "w") != null) && (...) || (...);
if (existed) {
 ...
}

所有的类都必须添加创建者和创建日期。

/**
* @author yangguanbao
* @date 2016/10/31
*/

注意 Math.random() 这个方法返回是 double 类型,注意取值的范围 0≤x<1(能够 取到零值,注意除零异常),如果想获取整数类型的随机数,不要将 x 放大 10 的若干倍然后 取整,直接使用 Random 对象的 nextInt 或者 nextLong 方法。

不要在 finally 块中使用 return。

MySQL 数据库

表达是与否概念的字段,必须使用 is_xxx 的方式命名,数据类型是 unsigned tinyint (1 表示是,0 表示否)。

小数类型为 decimal,禁止使用 float 和 double。

varchar 是可变长字符串,不预先分配存储空间,长度不要超过 5000,如果存储长度 大于此值,定义字段类型为 text,独立出来一张表,用主键来对应,避免影响其它字段索引效 率。

表必备三字段:id, create_time, update_time。 说明:其中 id 必为主键,类型为 bigint unsigned、单表时自增、步长为 1。create_time, update_time 的类型均为 datetime 类型,前者现在时表示主动式创建,后者过去分词表示被动式更新。

表的命名最好是遵循“业务名称_表的作用”。

业务上具有唯一特性的字段,即使是组合字段,也必须建成唯一索引。

当某一列的值全是 NULL 时,count(col)的返回结果为 0,但 sum(col)的返回结果为 NULL,因此使用 sum()时需注意 NPE 问题。

正例:可以使用如下方式来避免 sum 的 NPE 问题:SELECT IFNULL(SUM(column), 0) FROM table;

sql.xml 配置参数使用:#{},#param# 不要使用${} 此种方式容易出现 SQL 注入。

分层领域模型规约:

• DO(Data Object):此对象与数据库表结构一一对应,通过 DAO 层向上传输数据源对象。

• DTO(Data Transfer Object):数据传输对象,Service 或 Manager 向外传输的对象。

• BO(Business Object):业务对象,可以由 Service 层输出的封装业务逻辑的对象。

• Query:数据查询对象,各层接收上层的查询请求。注意超过 2 个参数的查询封装,禁止使用 Map 类 来传输。

• VO(View Object):显示层对象,通常是 Web 向模板渲染引擎层传输的对象。

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

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值