lombok + slf4j + log4j2

1.lombok插件介绍

  参考  https://blog.csdn.net/a2267378/article/details/81180373,    https://www.cnblogs.com/heyonggang/p/8638374.html

2.安装

  jar包依赖

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

  IDEA需要同时下载插件

 

  选择从浏览器下载,安装后重启即可

3.使用

import lombok.extern.slf4j.Slf4j;

@Slf4j
public class Test1 {

    public static void main(String[] args) {
        log.trace("trace11111111111");
        log.debug("debug11111111");
        log.info("ino11111111111");
        log.warn("dddddddddddddddddd");
        log.error("eeeeeeeeeeeeeeeee");
        try {
            int a=1/0;
        } catch (Exception e) {
            log.error(e.getMessage(),e.fillInStackTrace());
        }
    }
}

4.常用注解

  @Data  (少用) :注解在类上;包含了@ToString,@EqualsAndHashCode,@Getter / @Setter和@RequiredArgsConstructor的功能,提供类所有属性的 getter 和 setter 方法,此外还提供了equals、canEqual、hashCode、toString 方法

  @Setter:注解在属性上;为属性提供 setter 方法

  @Getter:注解在属性上;为属性提供 getter 方法

  @ToString:注解在类上;生成toString()方法,默认情况下,它会按顺序(以逗号分隔)打印你的类名称以及每个字段。可以这样设置不包含哪些字段@ToString(exclude = "id") / @ToString(exclude = {"id","name"}) 

  @EqualsAndHashCode:注解在类上;生成hashCode()和equals()方法,默认情况下,它将使用所有非静态,非transient字段。但可以通过在可选的exclude参数中来排除更多字段。或者,通过在parameter参数中命名它们来准确指定希望使用哪些字段。

  @NonNull:  注解在属性上;标识属性是不能为空,为空则抛出异常。

  @Slf4j :注解在类上;根据用户实际使用的日志框架生成log日志对象。

  @Log4j :注解在类上;为类提供一个 属性名为log 的 log4j 日志对象

  @NoArgsConstructor:注解在类上;为类提供一个无参的构造方法。当类中有final字段没有被初始化时,编译器会报错,

  @AllArgsConstructor:注解在类上;为类提供一个全参的构造方法

  @RequiredArgsConstructor:注解在类上;会生成构造方法(可能带参数也可能不带参数),如果带参数,这参数只能是以final修饰的未经初始化的字段,或者是以@NonNull注解的未经初始化的字段@RequiredArgsConstructor(staticName = "of")会生成一个of()的静态方法,并把构造方法设置为私有的。

  @Builder:效果同构建者模式的Builder

import lombok.Builder;

@Builder
public class Stu {
    private int id;
    private String name;
    private String hometown;
    public String toString(){
        return "id="+this.id+";name="+this.name+";hometown="+this.hometown;
    }
    public static void main(String[] args) {
        Stu s=new Stu.StuBuilder().hometown("81").id(1).name("a").build();
        System.out.println(s.toString());
    }
}

 

posted @ 2019-12-06 15:23  hjy1995  阅读(3964)  评论(0编辑  收藏  举报