14 个 SpringBoot 优化小妙招,写代码像写诗

说到代码优化,很多人上来就是各种理论、架构、核心思路;其实优化这个事情说简单也简单,说复杂也可以很复杂,但是我觉得最重要的就是要有一个良好的编码习惯,代码"屎山”并非一朝一夕形成的,往往是经过了日积月累;

因此,培养一个好的习惯,可以让我们的代码变的更加优雅、易维护,系统变的更加健壮;下面就分享14个小技巧,让优化变成顺手就完成的小事儿;

# 定义配置文件信息

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

例如

图片

用 @ConfigurationProperties 代替@Value

使用方法

定义对应字段的实体

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

使用时注入这个bean

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

# 用@RequiredArgsConstructor代替@Autowired

我们都知道注入一个bean有三种方式哦(set注入, 构造器注入, 注解注入),spring推荐我们使用构造器的方式注入Bean

我们来看看上段代码编译完之后的样子

图片

RequiredArgsConstructor:lombok提供

# 代码模块化 

阿里巴巴Java开发手册中说到每个方法的代码不要超过50行(我没记错的话)

在实际的开发中我们要善于拆分自己的接口或方法, 做到一个方法只处理一种逻辑, 说不定以后某个功能就用到了, 拿来即用

图片

# 抛异常而不是返回

在写业务代码的时候,经常会根据不同的结果返回不同的信息,尽量减少返回,会显得代码比较乱

反例

图片

正例

图片

# 减少不必要的db

尽可能的减少对数据库的查询

举例子

删除一个服务(已下架或未上架的才能删除)之前有看别人写的代码,会先根据id查询该记录,然后做一些判断

反例

图片

正例

图片

# 不要返回null 

反例

图片

正例

图片

别处调用方法时,避免不必要的空指针

# if else 

不要太多了if else if

可以试试策略模式代替

 
 

# 减少controller业务代码

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

反例 

图片

正例

图片

# 利用好Idea

目前为止市面上的企业基本都用idea作为开发工具了吧

举一个小例子

idea会对我们的代码进行判断,提出合理的建议

例如:

图片

它推荐我们用lanbda的形式代替,点击replace

图片

# 阅读源码

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

# 设计模式

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

# 拥抱新知识

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

# 基础问题 

map遍历

 

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

optional 判空

//获取子目录列表public List<CatalogueTreeNode> getChild(String pid) {    if (V.isEmpty(pid)) {        pid = BasicDic.TEMPORARY_DIRECTORY_ROOT;    }    CatalogueTreeNode node = treeNodeMap.get(pid);     return Optional.ofNullable(node)              .map(CatalogueTreeNode::getChild)              .orElse(Collections.emptyList());}

递归

大数据量的递归时,避免在递归方法里new对象,可以试试把对象当作方法参数进行传递使用

注释 

类 接口方法 注解 较复杂的方法 注释都要写而且要写清楚, 有时候写注释不是给别人看的 而是给自己看的

# 判断元素是否存在

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(即链表中)

 

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

由此可见其复杂度为O1

最后说一句(求关注!别白嫖!)

如果这篇文章对您有所帮助,或者有所启发的话,求一键三连:点赞、转发、在看。

关注公众号:woniuxgg,在公众号中回复:笔记  就可以获得蜗牛为你精心准备的java实战语雀笔记,回复面试、开发手册、有超赞的粉丝福利!

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

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值