告别“繁文缛节”,Coding神兵利器

懒惰是人类文明进步的真正动力

我一直认为“懒惰”是程序员身上应该具有的气质,它会帮助程序员努力地想办法去告别各种各样的重复劳动,比如CI给软件交付带来的巨大变化。如果不想着如何去“懒惰”,那程序员这个脑力劳动者就会真的变成“体力搬砖”、“人肉运维”,谁不希望需求少变化、代码少出错、晚上少加班。

程序员的自白

告别“体力搬砖”和“人肉运维”的最直接的方法就是少写代码少出错,之前的文章已经介绍了如何利用快捷键(快捷键,了解一下)来产生又好又快的工作输出。这次我将从代码的角度给大家介绍一种少写代码的工具Lombok。

什么是Lombok

Java语言频繁被人诟病的一个问题是总会有大量“样板化”的代码,例如我们常见的各种各样的get、set,刚开始时这些样板让我们觉得上手容易,但时间长了就会觉得这些样板真无趣,而Lombok的目标就是通过注解来替换这些样板化的文件,例如使用@Data来表述类需要提供的样板方法。

lombok @Data

光看到这里就可以想象到使用了Lombok之后,我们可以少写多少代码,是不是心里有点小激动呢?

想想还有点小激动呐

如何使用Lombok

集成Lombok比较容易,官方的教程提供了pom范例只需要增加依赖即可,不过官方的的教程有个问题,教程上给出的Lombok版本太低了,导致编译时会报错。正确可用的方式如下:

    
        
            org.projectlombok
            lombok
            RELEASE
            provided
        
    
    
        
            projectlombok.org
            http://projectlombok.org/mavenrepo
        
    

Lombok的花式注解

我们都知道一个常见的Java类定义会包括类字段定义以及相应的getter和setter,此外还有hashCode和equals方法,而利用Lombok这些都能轻松搞定,比如我们上面谈到@Data,你可以把代码写成以下的样式:

@Data
public class Person {
    private final String name;
    private final Gender gender;
    private String id;

    enum Gender{ Male, Female }

    public Person(String name, Gender gender) {
        this.name = name;
        this.gender = gender;
    }
}

虽然没有写equals和set方法但却可以直接使用,这就是Lombok的神奇之处,对于一般的类基本上写完类字段就完成了整个类的基础,剩下的就是关注那些需要实现的特定功能了。

@Test
public void should_be_same_person_when_all_match() throws Exception {
    // given
    final Person p1 = new Person("John", Male);
    p1.setId("123456");
    final Person p2 = new Person("John", Male);
    p2.setId("123456");
    // when
    // then
    assertThat(p1.equals(p2), is(true));
}

除去@Data外,Lombok还有很多非常有用的注解,下面介绍几种可以被我们经常使用的注解,如果想要了解更多Lombok信息,可以从其官网上获得。

  • @Getter和@Setter,如其名,在类字段上使用该注解后就会产生相应的方法,不同类型的字段产生的方法会稍微不同(如boolean产生的getter方法就是isXXX),此外该注解还提供了一个可选参数来定制方法的访问权限;
  • @NonNull,该注解用于表明需要对字段进行非null检查;
  • @ToString,使用该注解可以产生toString方法,该注解还提供参数来指定需要在toString方法中引用的字段;
  • @EqualsAndHashCode,如其名,使用该注解可产生equals与hashCode方法,同时与@ToString类似,也可以通过参数来制定方法中引用的字段;
  • @Data,可以简单地认为是@ToString、@EqualsAndHashCode、@Getter和@Setter的集合体。

Lombok后话

不论是快捷键或是Lombok,核心的思想都是运用成熟的技术来实现代码产出的速率与质量,减少程序员思考句式、语法的消耗,而把精力放在关注代码核心的逻辑与算法上,是“Less is More”思想的体现。

如果你真的想和“繁文缛节”说拜拜,那就不妨试一试Lombok,释放自己的一点“懒惰”去创造更好的未来。

你可能感兴趣的:(告别“繁文缛节”,Coding神兵利器)