代码瘦身优化实践

史蒂夫.乔布斯说,”复杂的终极境界是简单“,同样的优雅的代码一定是精简明了,可读性好。


使用LocalDate和LocalDateTime

 LocalDate精确到日期,LocalDateTime精确到时分秒。 优化前14行代码 

try{
SimpleDateFormat sdfDay = new SimpleDateFormat("yyyy-MM-dd");
SimpleDateFormat sdfMins = new SimpleDateFormat("yyyy-MM-dd HH:mm:ss");
Date now = new Date();
String today = sdfDay.format(now);
String waterStart = today + " 03:00:00";
String waterEnd = today + " 04:00:00";

Date waterStartTime = sdfMins.parse(waterStart);
Date waterEndTime = sdfMins.parse(waterEnd);
}catch (ParseException pe) {
  return XX;
}

优化后3行代码

LocalDateTime now = LocalDateTime.now();
LocalDateTime waterStart = LocalDateTime.of(now.getYear(), now.getMonth(),now.getDayOfMonth(),3,0);
LocalDateTime waterEndTime =LocalDateTime.of(now.getYear(), now.getMonth(),now.getDayOfMonth(),4,0);

默认值使用Optional

优化前五行

if (null == status) {
   param.put("status", new ArrayList<String>());
  } else {
    param.put("status", status);
  }

优化后一行,使用JDK8的Optional

Optional.ofNullable(status).orElse(new ArrayList<String>());

如果是字符串可以用

StringUtils.defaultIfEmpty(status,"")

字符串累加

 字符串只要不在for循环里累加,可以直接用+号,因为编译成字节码后会变成StringBuilder,如果在for循环里面用+号会生成多个StringBuilder,所以在for循环里累加最好在循环外创建StringBuilder。 优化前五行 

StringBuffer sblog = new StringBuffer();
sblog.append("waterDriven|sellerId=");
sblog.append(request.getSellerTaobaoId());
sblog.append("|result=");
sblog.append(isSuccess);

 优化后一行 

String sblog="waterDriven|sellerId="+request.getSellerTaobaoId()+"|result="+isSuccess;

 以上场景用逗号和等号连接数据,使用GUAVA的Joiner更精简,可读性更好 

String sblog=Joiner.on("|").withKeyValueSeparator("=")
                .join(ImmutableMap.of("sellerId", request.getSellerTaobaoId(), "result", isSuccess))

LIST TO MAP

 优化前4行 

Map<String, String> AssetsMetaIdMap = Maps.newHashMap();
        for (AssetsInfoBO assetsInfoBO : request.getAssetsCollectionList()) {
           AssetsMetaIdMap.put(assetsInfoBO.getAssetMetadataId(), assetsInfoBO.getAssetMetadataId());
        }

 优化后1行 

Map<String, String> AssetsMetaIdMap = request.getAssetsCollectionList().stream().collect(Collectors.toMap(Hosting::getAssetMetadataId, Hosting::getAssetMetadataId));

 如果key重复会抛出异常

Exception in thread "main" java.lang.IllegalStateException: Duplicate key 80000

减少不需要的判断

 优化前5行 

String requestId = null;
if (null != request.getExtData()) {
    requestId = request.getExtDataValue(REQUEST_ID_KEY);
}
return requestId;

优化后1行

return request.getExtDataValue(REQUEST_ID_KEY);

去掉else

 优化前5行 

if (null != result && StringUtils.isNotBlank(no)) {
     return no;
 } else {
 throw new RuntimeException("XX");
 }

 优化后4行 

if (null != result && StringUtils.isNotBlank(no)) {
     return no;
 } 
 throw new RuntimeException("XX");

不要返回布尔

 优化前5行 

if ("true".equalsIgnoreCase(value.toString())) {
    invoke = true;
 } else {
    invoke = false;
 }

 优化后一行 

invoke = "true".equalsIgnoreCase(value.toString());

使用级联

优化前5行 

ParamBO paramBO = new ParamBO();
paramBO.setId(1);
paramBO.setName(”ifeve“);
paramBO.setOld(7);

优化后1行

new ParamBO().withId(1).withName("ifeve").withOld(7);

原创文章,转载请注明: 转载自并发编程网 – ifeve.com本文链接地址: 代码瘦身优化实践

  • Trackback 关闭
  • 评论 (3)
    • facesun
    • 2019/03/17 11:07上午

    第一个例子为什么不用Calendar

      • nayan3480232
      • 2019/03/20 5:42下午

      感觉Calendar 应该比LocalDateTime麻烦把

    • Waldeinsamkeit
    • 2019/05/28 10:15下午

    jdk的collector抛key重复异常那个,更建议用guava的multiMap

return top