从今天起让我们忘记Java中的get/set方法吧!

今天给大家推荐一款神器!让我们可以以一种更优雅的姿势编写我们的get/set方法。

曾几何时,我们写代码的时候,每次写Bean的时候都会使用快捷键生成get/set方法,有时候我经常会想,既然每一个Bean我们都会给其提供get/set方法,那么为什么还有会这个东西哪?(当然这只是一个问题,毕竟还是很有用的,这一点就是Java语言中的private、public等作用域)

今天说的当然不是这个,我们讨论的是希望有一种优雅的方式编写我们的get/set方法或者说是一种优雅的简化。那我们就说一下今天的主角吧!

Lombok

Java代码简化神器!就是如此美妙!

Lombok是一个可以通过简单的注解形式来帮助我们简化消除一些必须有但显得很臃肿的Java代码的工具,通过使用对应的注解,可以在编译源码的时候生成对应的方法。

https://projectlombok.org/

https://github.com/rzwitserloot/lombok

如何使用

1、安装IDEA插件Lombok Plugin

2、引入pom,最新版本为1.16.18

3、简单使用,设置get/set方法

4、稍微复杂一点的使用

其他使用

上述只是展示了几个最常用的特性,其他的还有很多,例如:

@NonNull、 @java.lang.Override、@Data、@SneakyThrows、@Synchronized、@Cleanup

具体的使用可以参考官方文档,这里只是给大家介绍一下如此美妙的东西!

Q:这么好的东西,他是什么原理哪?

A:首先我们应该清楚,我们第一步是需要安装IDEA的插件,只有安装了插件我们才可以在代码中直接使用get和set方法,如果没有话他会直接报错的,就是没有get和set方法,安装了插件我们就可以使用这些方法,并且在编译之后的class文件中也是有这些方法的。当然,为什么装了插件之后就可以调用了,这个问题太过深奥,这里不再细聊,有兴趣的可以参考相关文章进行学习。

一些思考

看到这里,很多人要说了,我使用的要么是SSM框架,要么是SSH框架,这些框架都可以使用逆向工程的方式生成我们的代码,当然包括Bean,我们在使用逆向工程的时候,get/set方法不都是自动生成的吗?使用这个Lombok尽管优美,我们还不是需要进行自己写注解的吗?

首先,我们先聊一下最近一个比较火的领域驱动设计中的贫血、失血、胀血和充血模型。

什么是贫血失血充血模型呢?简单来说:

1、失血模型:模型仅仅包含类的属性和getter/setter方法,业务逻辑和应用逻辑都放到服务层中。这种类在Java中叫POJO或者Bean。

2、贫血模型:贫血模型中包含了一些业务逻辑,但不包含依赖持久层的业务逻辑。这部分依赖于持久层的业务逻辑将会放到服务层中。可以看出,贫血模型中的领域对象是不依赖于持久层的。

3、充血模型:充血模型中包含了所有的业务逻辑,包括依赖于持久层的业务逻辑。所以,使用充血模型的领域层是依赖于持久层,简单表示就是 UI层->服务层->领域层持久层。

4、胀血模型:胀血模型就是把和业务逻辑不相关的其他应用逻辑(如授权、事务等)都放到领域模型中,这是一种极差的设计方式。

看到这里,可能大家一脸迷茫!这样说吧,领域驱动模型设计的一个特点是对于一个实体对象,它不但有相关的属性还要有其自身的方法(他的能力,可以做的事情)。

举个栗子:一个User类,不但要有人的基本属性,还要有这个人能做的事情(不仅仅是get/set方法)但是,这一看就是一个充血模型,但是只有基本的属性和get/set方法的话他就是一个失血模型了,因此对于领域驱动来说,我们可以这样操作,通过一个DTO包含其所有的基本属性和get/set方法,然后领域实体对象继承这个DTO,当然这只是一种用法!

图:领域驱动的一种使用模式

因此对于一个充血模型的领域驱动实体对象来说,他不但有属性还有他的各种方法,如果整个的都放在一个类里的话根本不好区分他到底是get/set方法还是其他功能方法,这里我们使用Lombok提供的注解的方式就刻意很完美的解决这个在编码过程中造成的不适感!

当然,对于领域驱动模型的研究还有很多,这里只是简单的介绍了我使用过的一种方式,仅供参考!

回过头来看

看到这里,貌似饶了一大圈还是没有说明白,我使用SSM好好的,然后代码都是自动生成的,我为什么还需要使用和这个Lombok哪?

其实不然,上述在介绍领域驱动的时候,我们也可以看到使用Lombok确实可以简化很多编辑器中显示的代码,是一种很优雅和美观的体现!

那我数据库有100多个表,又没法使用以前的逆向工具生成代码,我该怎么办哪?当然是造---造轮子了!

使用过MyBatis的朋友很多都知道,可以很方便的使用逆向工程生成我们需要的代码,我们如果引入Lombok的话,我们只有把他加入到逆向工程里生成我们的代码才可以避免庞大的工作量。

估计有些小伙伴们已经方了,这么高大上的东西自己怎么可能搞定那?不用担心,我个人曾经尝试过使用简单的代码实现类似的代码生成工具。当你去尝试的时候,就会知道,也不过如此!过程大致是这样的:

看一个简单的FreeMarker的关于Bean的一个简单模板配置,虽然看着复杂,但是都结构化的格式,使用模板配置我们不但可以生成Bean、还可以生成Service、Controller等任何我们需要的代码:

当然,我们也可以在开源项目的基础上进行修改的,这样的话更加容易一些!常见的有mybatis-plus提供的一个代码生成工具,可以参考!

好啦!今天给大家介绍了代码简化神器Lombok,还有代码生成器的基本思路,有了Lombok!就让我们忘了Java代码中冗长杂乱的get/set方法吧!

本文来自企鹅号 - Java后端技术媒体

发表于

我来说两句

0 条评论
登录 后参与评论

相关文章

来自专栏数据派THU

手把手教你用Pandas透视表处理数据(附学习资料)

来源:伯乐在线 - PyPer 本文共2203字,建议阅读5分钟。 本文重点解释pandas中的函数pivot_table,并教大家如何使用它来进行数据分析...

1915
来自专栏CDA数据分析师

深入对比数据科学工具箱:Python和R之争

概述 在真实的数据科学世界里,我们会有两个极端,一个是业务,一个是工程。偏向业务的数据科学被称为数据分析(Data Analysis),也就是A型数据科学。偏向...

1997
来自专栏逻辑熊猫带你玩Python

Python | "整理一些模块,不用也能拿来吹"

2、刚好今天有读者向我提问的时候,看到有这么道题,写出你使用过的模块,并简单描述一下。

854
来自专栏令仔很忙

UML之用例图

  在UML实践中,用例图(Usecasediagrams)就是软件外部特性描述的视图,是以用户的角度、以一种可视化的方式来描述软件产品的需求,分析软件的功能和...

631
来自专栏北京马哥教育

Python新手应该如何练手?知乎5600赞答案告诉你!

作者:小小搬运工 链接:https://www.zhihu.com/question/29372574/answer/88624507 一直在学习python,...

3377
来自专栏WOLFRAM

强大的 Wolfram 11.0(下)

1084
来自专栏Python小屋

Python计算信息熵

信息熵可以用来判定指定信源发出的信息的不确定性,信息越是杂乱无章毫无规律,信息熵就越大。如果某信源总是发出完全一样的信息,那么熵为0,也就是说信息是完全可以确定...

2694
来自专栏互联网杂技

2017 年,谷歌开源了这些超酷炫的项目

在开源和贡献开源方面,Google 一直是行业的典范。2017年,Google 在 GitHub 上大约有 900 名活跃用户,共推送约 1100 个顶级库。

872
来自专栏cs

用列图

1284
来自专栏大数据文摘

手把手 | 数据科学速成课:给Python新手的实操指南

1505

扫码关注云+社区