从今天起让我们忘记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 条评论
登录 后参与评论

相关文章

来自专栏上善若水

### 0x01 C++ 资源大全

关于 C++ 框架、库和资源的一些汇总列表,内容包括:标准库、Web应用框架、人工智能、数据库、图片处理、机器学习、日志、代码分析等。

1863
来自专栏VRPinea

撩妹必备技能之:如何用Unity 3D创建一个VR场景?

1.3K4
来自专栏机器之心

教程 | 如何使用Docker、TensorFlow目标检测API和OpenCV实现实时目标检测和视频处理

选自TowardsDataScience 作者:Léo Beaucourt 机器之心编译 参与:李诗萌、路雪 本文展示了如何使用 Docker 容器中的 Ten...

4166
来自专栏玉树芝兰

如何用VOSviewer分析CNKI关键词共现?

用VOSviewer尝试CNKI中文文献关键词共现(keyword co-occurence)分析时,你可能会踩到一个大坑。本文帮助你绕开这个坑,或是从坑里爬出...

802
来自专栏CSDN技术头条

介绍两款大数据清洗工具——DataWrangler、Google Refine

在进行数据分析和可视化之前,经常需要先“清洗”数据。这意味着什么?可能有些词条列表里是“New York City”,而其他人写成“New York,NY”。然...

4849
来自专栏美团技术团队

顶会论文:纠删码存储系统中的投机性部分写技术

本文已被USENIX'17年度技术大会录用,此处为中文简译版。 阅读英文论文完整版请点击:Speculative Partial Writes in Erasu...

55010
来自专栏跟着阿笨一起玩NET

C#中的串口通信

串行接口按电气标准及协议来分,包括RS-232-C、RS-422、RS485、USB等。 RS-232-C、RS-422与RS-485标准只对接口的电气特性做出...

1442
来自专栏aCloudDeveloper

初识The ONE

Author:bakari  Date:2014.1.14       本学期开始做真正意义上的研究,主要方向为wireless and mobile netw...

2186
来自专栏刘君君

Rest Notes-表述性状态移交(Representational State Transfer ,REST)

1745
来自专栏逍遥剑客的游戏开发

一个困扰我一个多星期的Nebula3的BUG

1313

扫码关注云+社区