2018-08-28 14:50:39

使用 Lombok 简洁优雅的优化你的实体类JavaBean代码-Java的奇淫巧技


使用 Lombok 简洁优雅的优化你的实体类JavaBean代码-Java的奇淫巧技

我一直坚持认为,作为程序员偷懒是优秀的品质,只有让人类更懒才能提升效率,让重复和简单的工作交给机器吧,今天给大家介绍的一款第三方库就是能帮你提升效率和偷懒的工具:Lombok,本次主要介绍的是利用 Lombok 来优化你的实体类代码,重复而又简单的 getter/setter/toString/equals 代码就交给程序来完成吧。

Lombok是一个第三方Java库,在项目开发中我们经常需要定义实体类大量的JavaBean,然后使用IDE的快捷键去构建getter/setter/toString/equals等方法,代码看着非常多,最重要的是遇到改名需要的时候,要批量替换,还可能替换出错,实在是痛苦不堪,Lombok可以帮我们在编译时完成复杂又低级的代码。官方地址:https://projectlombok.org/,github地址:https://github.com/rzwitserloot/lombok


首先要在项目中引入Jar包,我使用Maven管理依赖,所以这里给出Maven的pom.xml代码:

<dependency>
    <groupId>org.projectlombok</groupId>
    <artifactId>lombok</artifactId>
    <version>1.18.2</version>
    <scope>provided</scope>
</dependency>


然后安装插件,因为要让IDE开发环境识别我们偷懒的写法不报错,就得安装lombok插件,我使用的是 idea,就以idea为例:在 File > Settings > Plugins,然后搜索”Lombok Plugin“,点击 Install plugin 安装插件,重新启动 idea 即可。

/31ca9e940cf949d29a3981593d0d2bc4.png

由于我已经转到SpringBoot下开发,能使用注解就使用注解,那加上Lombok的加持,就会产生这样的实体类:

@Data
public class Link {
    private String href;
    private String text;
    private String target;
}

通过代码可以看到,没有 getter/setter/toString等代码,只有一个@Data注解,这个Data注解就是在lombok.Data,这个@Data又包含:@ToString、@Getter、@Setter、@EqualsAndHashCode、@NoArgsConstructor,这就热闹了,都是啥意思呢?先不多说,我们看看编译以后的 Link.class 文件里都是什么内容:

package com.neilren.neilren4j.entity;

public class Link {
    private String href;
    private String text;
    private String target;

    public Link() {
    }

    public String getHref() {
        return this.href;
    }

    public String getText() {
        return this.text;
    }

    public String getTarget() {
        return this.target;
    }

    public void setHref(String href) {
        this.href = href;
    }

    public void setText(String text) {
        this.text = text;
    }

    public void setTarget(String target) {
        this.target = target;
    }

    public boolean equals(Object o) {
        if (o == this) {
            return true;
        } else if (!(o instanceof Link)) {
            return false;
        } else {
            Link other = (Link)o;
            if (!other.canEqual(this)) {
                return false;
            } else {
                label47: {
                    Object this$href = this.getHref();
                    Object other$href = other.getHref();
                    if (this$href == null) {
                        if (other$href == null) {
                            break label47;
                        }
                    } else if (this$href.equals(other$href)) {
                        break label47;
                    }

                    return false;
                }

                Object this$text = this.getText();
                Object other$text = other.getText();
                if (this$text == null) {
                    if (other$text != null) {
                        return false;
                    }
                } else if (!this$text.equals(other$text)) {
                    return false;
                }

                Object this$target = this.getTarget();
                Object other$target = other.getTarget();
                if (this$target == null) {
                    if (other$target != null) {
                        return false;
                    }
                } else if (!this$target.equals(other$target)) {
                    return false;
                }

                return true;
            }
        }
    }

    protected boolean canEqual(Object other) {
        return other instanceof Link;
    }

    public int hashCode() {
        int PRIME = true;
        int result = 1;
        Object $href = this.getHref();
        int result = result * 59 + ($href == null ? 43 : $href.hashCode());
        Object $text = this.getText();
        result = result * 59 + ($text == null ? 43 : $text.hashCode());
        Object $target = this.getTarget();
        result = result * 59 + ($target == null ? 43 : $target.hashCode());
        return result;
    }

    public String toString() {
        return "Link(href=" + this.getHref() + ", text=" + this.getText() + ", target=" + this.getTarget() + ")";
    }
}

现在就看明白了吧,@Data包含:@ToString、@Getter、@Setter、@EqualsAndHashCode、@NoArgsConstructor。@ToString会为我们添加toString()方法,@Getter、@Setter会为我们添加 get()、set()方法,@EqualsAndHashCode会给我们添加equals(Object o)、hashCode()方法,@NoArgsConstructor会给我们添加一个无参数的构造函数,在这里就是添加了Link()方法,怎么样是不是很爽?

再介绍一些好用的注解:

@NonNull:在方法或构造函数上加@NonNull注释,会为我们增加一个Null空值检查语句,遇到空值会抛出一个NullPointerException异常

@Cleanup:在使用类似InputStream、OutputStream资源的时候能为我们自动的释放资源,也就是会为我们增加 资源close()方法

还有很多注释,就不介绍了,这些常用的就基本够用了,接下来再介绍一个输出日志的注解@Slf4j,当我们引入Lombok的时候,@Slf4j也可以被使用了,用法是在类名上面增加@Slf4j的注解,然后在类里面使用log.info()或者log.error()方法输出和记录日志:

@Slf4j
@Service
public class IpInfoService extends BaseService {
    public AlicmapiIP getIpInfo(String ip) {
        try {
        } catch (Exception e) {
            log.error(e.getMessage(), e);
        }
        return null;
    }
}

通过配置文件可以配置日志输出位置和分级别输出。

最后说一下Lombok,一直有一些争议,应不应该使用,可以根据实际场景进行使用。


商业用途请联系作者获得授权。
版权声明:本文为博主「任霏」原创文章,遵循 CC BY-NC-SA 4.0 版权协议,转载请附上原文出处链接及本声明。
原文链接:https://www.renfei.net/posts/1003280
评论与留言
以下内容均由网友提交发布,版权与真实性无法查证,请自行辨别。

本站有缓存策略,时间约2小时后能看到您的评论。本站使用自动审核机制,如果您的内容包含广告/谩骂/恐怖/暴力/涉政等不和谐内容将无法展示!


本站有缓存策略,时间约2小时后能看到您的评论。本站使用自动审核机制,如果您的内容包含广告/谩骂/恐怖/暴力/涉政等不和谐内容将无法展示!

关注任霏博客
扫码关注「任霏博客」微信订阅号
微博:任霏博客网
Twitter:@renfeii
Facebook:任霏
最新留言 优先级低的并不代表一定要等到优先级高的运行完才能运行,只是cpu分配的资源少了而已。 /lib64/ld-linux-x86-64.so.2: No such file or directory 报了这个错误,怎么解决呢 对于一个布道 DevOps 多年的选手来讲,看到这个报告,还是想继续布道布道。虽然是各种对比哈,但是我感觉与 DevOps 太像了(可能是职业病犯了哈)。首先声明本人不是GitLab 用户(因为不免费,没法薅羊毛啊),本人是 GitHub 忠实用户。 首先,你这是田忌赛马的对比,中文对比一事,着实有点可笑 1 土生土长和外来户能立马拉到同一个起跑线上吗? 2 一个真正的开发者应该去提升自己的英语能力,而不是拿全部是中文文档说事。大家都知道现在开源非常热,开发者是开源的主力军,如果要贡献优秀的开源项目(诸如Linux 内核,Kubernetes),英语就是个硬门槛。如果我是你,我倒希望公司内部的系统是英文的,最起码能让我锻炼英语,在看开源项目文档的时候不至于看不懂,提 PR 的时候不至于提交代码的内容描述不清楚而没法被 Merge。 其次,阿里云效、Coding 大家都知道背后站的是谁,很容易造成厂商绑定,现在很多企业都希望不要被厂商绑定。 再者,有一个点需要明白,GitLab 是一个 DevOps 平台,什么叫做 DevOps 平台(DevOps 走到现在,确切的说应该叫做 DevSecOps)?就是覆盖了软件开发生命周期全阶段的,从项目管理到代码托管到安全再到日志监控、甚至包含现在的云原生能力。不仅仅是说一个 CI/CD 就能概括的了的。这一点是 DevOps 布道的真正误区,我见过太多了,我在这儿再布道一哈,CI/CD 不等于 DevOps,他只是 DevOps 落地实践的核心能力。仅凭借一个 CI/CD 能有现成模版就判断出哪个好坏,过于牵强了吧。相信大家真正到项目用的时候,模版是满足不了要求的吧,毕竟大家都很特性化。 最后,还是一个很热的话题,开源,open source。GitLab 是开源的,Coding 和 云效这方面我没看到相关的开源内容(可能是我孤陋寡闻)。大家可以看看国内有多少用 GitLb 的,GitLab 的 CE 版,然后私有化部署,就是很多公司的代码托管 + DevOps 解决方案。 个人愚见,做一些对比报告的时候,还是先需要明白这个产品的定位,去深入挖掘一些真正有意义的对比,这样的对比报告才能有意义。作为一个常年写博客、文章的人来说。你写的每个字、每篇文章,你要想到你的思想会影响到别人。有可能因为你的片面之词,让别人错失一些学习的好机会。 docker run 那一长串后,出来一个字符串,然后去 docker containers 下面看 显示 exited(1);logs 下就一行错误 initdb failed 感谢🙏,第一个问题是空格的问题应该,我逐字敲完后可以构建了.第二个问题是我docker环境的问题,docker更新为最新版后需要重置配置文件.现已经正常使用,再次感谢您的分享和您的细心解答,期待下次相遇😄 还有一个问题可以请教下吗?就是我在容器里建文件夹没有权限,su root后密码不知道是多少,sudo mkdir xxx 提示我,没有sudo命令,请问有好的解决方法吗?谢谢解答 -v 后面可以指定文件吗 我的也是报错,还有。我执行了这个:@localhost kingbase-es-v8-r3-docker % docker run -d --name kingbase -p 54321:54321 -e SYSTEM_PWD=SYSTEM -v /opt/kingbase/data:/opt/kingbase/data -v /opt/kingbase:/opt/kingbase/Server/bin kingbase:v8r3 docker: 'run -d --name kingbase -p 54321:54321 -e SYSTEM_PWD=SYSTEM -v /opt/kingbase/data:/opt/kingbase/data -v /opt/kingbase:/opt/kingbase/Server/bin kingbase:v8r3' is not a docker command. See 'docker --help' 麻烦帮忙看下,是不是我写的命令有问题,还是版本问题,谢谢啦 请问我build的时候一直报错,是资源没了吗?failed to solve with frontend dockerfile.v0: failed to create LLB definition: failed to do request: Head "https://reg-mirror.qiniu.com/v2/library/centos/manifests/7?ns=docker.io": Moved Permanently 能不能在代码那里详细解释一下啊,没完全懂呀 en 按照路径上的来操作的,但是启动时一直报:zsh: no such file or directory: docker run -d --name kingbase -p 54321:54321 -e SYSTEM_PWD=SYSTEM -v /Volumes/installation/opt/kingbase/data:/opt/kingbase/data -v /Volumes/installation/opt/kingbase/bin/license.dat:/opt/kingbase/Server/bin/license.dat kingbase:v8r3 错误