【java高手进阶之码上好习惯】


1. 定义配置文件信息

有时我们会为了统一管理,把一些变量放到yml配置文件中
例如:

developr:
  name: liangyun du
  website: https://editor.csdn.net/md
  qq: 998877456
  phone-number: 12564566445

用@configurationProperties 代替 @Value
使用方法
定义对应字段的实体

@Data
// 指定前缀
@ConfigurationProperties(prefix = "developer")
@Component
public class DeveloperProperty {
    private String name;
    private String website;
    private String qq;
    private String phoneNumber;
}

2. 用@RequiredArgsConstructor代替@Autowired

我们都知道注入一个 bean 有三种方式哦(set 注入, 构造器注入, 注解注入),Spring 推荐我们使用构造器的方式注入 Bean
用@Autowired会给予警告
@RequiredArgsConstructor 由lombok提供
使用时注入这个bean

@RestController
@RequiredArgsConstructor
public class PropertyController {
    private DeveloperProperty developerProperty;
    @GetMapping("/property")
    public Object index() {
       return developerProperty.getName();
    }
}

3. 代码模块化

阿里巴巴 Java 开发手册中说到每个方法的代码不要超过 50 行,
在实际的开发中我们要善于拆分自己的接口或方法, 做到一个方法只处理一种逻辑, 说不定以后某个功能就用到了, 拿来即用。
在这里插入图片描述

4. 抛异常而不是返回

在写业务代码的时候,经常会根据不同的结果返回不同的信息,尽量减少返回,会显得代码比较乱
代码如下(示例):
反例
在这里插入图片描述
正例
在这里插入图片描述

5. 减少不必要的db

尽可能的减少对数据库的查询
举例子
删除一个服务(已下架或未上架的才能删除),
先根据id查询该记录,然后做一些判断

6. 不要返回 null

别处调用方法时,避免不必要的空指针
用return Collections.emptyMap()代替return null

7. 不要太多 if else

不要太多if else if,可以试试策略模式代替

8. 减少controller业务代码

业务代码尽量放到service层进行处理,后期维护起来也好操作而且美观

9. 利用好Idea

目前为止市面上的企业基本都用idea作为开发工具了吧
举一个小例子
在这里插入图片描述
idea会对我们的代码进行判断,提出合理的建议
在这里插入图片描述

10. 阅读源码

一定要养成阅读源码的好习惯包括优秀的开源项目GitHub上stars:>1000, 会从中学好好多知识包括其对代码的设计思想以及高级API,面试加分(好多面试官习惯问源码相关的知识)

11. 设计模式

23种设计模式,要尝试代码中运用设计模式思想,写出的代码即规范又美观还高大上。

12. 拥抱新知识

像我们这种工作年限少的程序员,我觉得要多学习自己认知之外的知识,不能每天crud,有机会就多用用有点难度的知识,没有机会(项目较传统),可以自己下班多些相关demo练习

13. map遍历

HashMap<String, String> map = new HashMap<>();
   map.put("name", "liu");
   for (String key : map.keySet()) {
     String value = map.get(key);
   }
   map.forEach((k, v) -> {
   });
  // 推荐
  for (Map.Entry<String, String> entry : map.entrySet()) {
 
 }

14. 注释

类 接口方法 注解 较复杂的方法 注释都要写而且要写清楚, 有时候写注释不是给别人看的 而是给自己看的。或者你不怕被揍就不要写。

15. 判断元素是否存在

hashSet 而不是 list,list 判断一个元素是否存在的代码

ArrayList<String> list = new ArrayList<>();
// 判断a是否在list中
for (int i = 0; i < list.size(); i++)
       if ("a".equals(elementData[i]))
          return i;

由此可见其复杂度为On,而hashSet底层采用hashMap作为数据结构进行存储,元素都放到map的key(即链表中)

// 判断a是否在set中
int index = hash(a);
return getNode(index) != null

由此可见其复杂度为O1。

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值