Lombok怎么快速构建JavaBean与日志输出
小编给大家分享一下Lombok怎么快速构建JavaBean与日志输出,相信大部分人都还不怎么了解,因此分享这篇文章给大家参考一下,希望大家阅读完这篇文章后大有收获,下面让我们一起去了解一下吧!
快速构建JavaBean与日志输出
我们在写基类JavaBean时,当定义了成员变量后,我们不得不添加构造器,setter/getter方法以及toString方法,虽然eclipse等开发工具有一键生成策略,但是对我们来说仍觉得繁琐,并且当我们在对该类进行添加或者删除成员变量操作时,我们又得人为的去增添或删除setter/getter方法,此等重复操作大大地刺激到了正处于开发崩溃边缘的程序员,因此,lombok应运而生,帮我们解决了“懒”的问题。
以前的JavaBean是这样的
现在的JavaBean是这样的
使用Lombok前的准备操作
①添加maven依赖,或者到官网下载对应jar包 https://projectlombok.org/download
<dependency> <groupId>org.projectlombok</groupId> <artifactId>lombok</artifactId> <version>1.16.16</version> </dependency>
②为eclipse等工具安装好插件
<1>将lombok.jar移到eclipse的安装目录
<2>在eclipse.in文件最后加入下面一行-javaagent:D:\install\jee-oxygen\eclipse\lombok.jar
<3>重启eclipse
操作指南:
构造器,日志等注解必须标注在类上,setter/getter等方法标注在类上时,作用在所有成员变量上,当标注在成员变量上时,只有该变量起作用。
注解的具体作用:
@NoArgsConstructor //空参构造器@AllArgsConstructor //全参构造器@Data //set,get,toString等方法@Accessors(chain=true) //链式风格访问,new Dept().setName("cmj").setDeptno(1000L).setDb_source("db01");
那么问题来了,当我们需要在getter方法中进行操作时,如当年龄字段为null时,我需要返回给我一个数字20,这我们该怎么办呢?
其实lombok还是很给力的,当注解和getter等方法有冲突时,该变量的注解将失去作用,其作用的将是我们自定义的方法。
@Slf4j
标注在类上,相当于
private final Logger logger = LoggerFactory.getLogger(XXX.class);
@NonNull: 可以帮助我们避免空指针。
使用lombok:
import lombok.NonNull; public class NonNullExample extends Something { private String name; public NonNullExample(@NonNull Person person) { super("Hello"); this.name = person.getName(); }}
不使用lombok:
public class NonNullExample extends Something { private String name; public NonNullExample(@NonNull Person person) { super("Hello"); if (person == null) { throw new NullPointerException("person"); } this.name = person.getName(); }}
@Cleanup: 自动帮我们调用close()方法。
使用@Cleanup:
import lombok.Cleanup;import java.io.*;public class CleanupExample { public static void main(String[] args) throws IOException { @Cleanup InputStream in = new FileInputStream(args[0]); @Cleanup OutputStream out = new FileOutputStream(args[1]); byte[] b = new byte[10000]; while (true) { int r = in.read(b); if (r == -1) break; out.write(b, 0, r); } }}
不用@Cleanup:
import java.io.*; public class CleanupExample { public static void main(String[] args) throws IOException { InputStream in = new FileInputStream(args[0]); try { OutputStream out = new FileOutputStream(args[1]); try { byte[] b = new byte[10000]; while (true) { int r = in.read(b); if (r == -1) break; out.write(b, 0, r); } } finally { if (out != null) { out.close(); } } } finally { if (in != null) { in.close(); } } }}
IDEA使用lombok输出日志
安装lombok插件
pom.xml加入依赖
<dependency> <groupId>org.projectlombok</groupId> <artifactId>lombok</artifactId> <optional>true</optional> <version>1.16.18</version> </dependency>
使用@Slf4j注解
使用log对象的info()方法
@RestController@Slf4jpublic class PaymentController { @Autowired private PaymentService paymentService; @GetMapping(value = "/payment/get/{id}") public CommonResult getById(@PathVariable("id") long id){ Payment result = paymentService.getPaymentById(id); log.info("查询结果:"+result); if(result!=null){ return new CommonResult(200,"查询成功",result); } else { return new CommonResult(444,"没有查到,ID:"+id,null); } }}
以上是“Lombok怎么快速构建JavaBean与日志输出”这篇文章的所有内容,感谢各位的阅读!相信大家都有了一定的了解,希望分享的内容对大家有所帮助,如果还想学习更多知识,欢迎关注编程网行业资讯频道!
免责声明:
① 本站未注明“稿件来源”的信息均来自网络整理。其文字、图片和音视频稿件的所属权归原作者所有。本站收集整理出于非商业性的教育和科研之目的,并不意味着本站赞同其观点或证实其内容的真实性。仅作为临时的测试数据,供内部测试之用。本站并未授权任何人以任何方式主动获取本站任何信息。
② 本站未注明“稿件来源”的临时测试数据将在测试完成后最终做删除处理。有问题或投稿请发送至: 邮箱/279061341@qq.com QQ/279061341