【源码远控】【5188源码】【c ++源码】lombok源码github

时间:2025-01-04 06:09:15 编辑:天津打车app源码 来源:鞍山直播源码

1.聊聊使用lombok@Builder踩到的坑
2.Spring Boot + EasyExcel导入导出,源码简直太好用了!源码
3.@NoArgsConstructor,源码 @RequiredArgsConstructor, @AllArgsConstructor

lombok源码github

聊聊使用lombok@Builder踩到的坑

       å‰è¨€

       ä»€ä¹ˆæ˜¯lombok

       Lombok项目是一个Java库,它会自动插入编辑器和构建工具中,Lombok提供了一组有用的注释,用来消除Java类中的大量样板代码。

       å¯¹lombok不熟悉的朋友,可以阅读一下官方文档,再来看本文。官方文档如下

       projectlombok.org/

正文

       æˆ‘们先来看一个小例子

       æé—®ï¼šmain函数会输出什么?

       ç­”案:空指针异常

Exceptioninthread"main"java.lang.NullPointerExceptionatcom.github.lybgeek.msg.test.User.addPositionList(User.java:)atcom.github.lybgeek.msg.test.User.main(User.java:)

       å›žç­”出正确答案的朋友,下文基本上可以不用看了。可能有些朋友会有疑问,我例子中明明使用了

privateList<String>positionList=newArrayList<>();

       ä¸ºä»€ä¹ˆè¿˜ä¼šæŠ¥ç©ºæŒ‡é’ˆï¼Ÿ

       çœŸç›¸å°±åœ¨lombok用@builder生成的class文件中,我们看下使用@builder,生成的class文件反编译后长啥样

       çœ‹åˆ°æˆ‘圈红起来的,大家应该就一目了然。原来当我们用

Useruser=User.builder().username("张三").build();

       æ—¶ï¼Œæ­¤æ—¶user对象中的positionList就会被userBuilder中的positionList覆盖,而userBuilder中的positionList是null

如何解决

       æ–¹æ³•ä¸€ï¼špositionList前面加上final修饰

privatefinalList<String>positionList=newArrayList<>();

       æ­¤æ—¶ç”¨@Budiler生成class为

       æ­¤æ—¶user对象中的positionList用的还是原先的positionList,因此不会出现空指针异常

       æ–¹æ³•äºŒï¼špositionList前面加上@Builder.Default注解

@Builder.DefaultprivateList<String>positionList=newArrayList<>();

       æ­¤æ—¶ç”¨@Budiler生成class为

publicstaticclassUserBuilder{ privateStringusername;privatebooleanpositionList$set;privateList<String>positionList;UserBuilder(){ }publicUser.UserBuilderusername(finalStringusername){ this.username=username;returnthis;}publicUser.UserBuilderpositionList(finalList<String>positionList){ this.positionList=positionList;this.positionList$set=true;returnthis;}publicUserbuild(){ List<String>positionList=this.positionList;if(!this.positionList$set){ positionList=User.$default$positionList();}returnnewUser(this.username,positionList);}

       å½“positionList$set为false,会给userBuilder的positionList赋值为

User.$default$positionList();即:privatestaticList<String>$default$positionList(){ returnnewArrayList();}

       å› æ­¤å½“user对象中的positionList被userBuilder中的positionList覆盖后,userBuilder中的positionList是newArrayList(),此时就不会出现空指针现象

       æ–¹æ³•ä¸‰ï¼šä¸ç”¨build实例化对象

       æŠŠ

Useruser=User.builder().username("张三").build();

       æ”¹æˆç”¨

Useruser=newUser();user.setUsername("张三");user.addPositionList("经理");总结

       å¾ˆå¤šæ—¶å€™æ²¡é‚£ä¹ˆå¤šçš„想当然

       ä½œè€…:linyb极客之路

Spring Boot + EasyExcel导入导出,简直太好用了!源码

       老项目主要采用的源码POI框架来进行Excel数据的导入和导出,但经常会出现OOM的源码源码远控情况,导致整个服务不可用。源码后续逐步转移到EasyExcel,源码简直不能太好用了。源码

       EasyExcel是源码阿里巴巴开源插件之一,主要解决了poi框架使用复杂,源码sax解析模式不容易操作,源码5188源码数据量大起来容易OOM,源码解决了POI并发造成的源码报错。主要解决方式:通过解压文件的源码方式加载,一行一行地加载,并且抛弃样式字体等不重要的数据,降低内存的占用。

       在之前专门写过一篇文章《EasyExcel太方便易用了,强烈推荐!》,介绍EasyExcel功能的基本使用。今天这篇文章,c ++源码我们基于SpringBoot来实现一下EasyExcel的集成,更加方便大家在实践中的直接使用。

       创建一个基础的SpringBoot项目,比如这里采用SpringBoot 2.7.2版本。

       EasyExcel在SpringBoot的集成非常方便,只需引入对应的pom依赖即可。在上述dependencies中添加EasyExcel的依赖:

       EasyExcel目前稳定最新版本2.2.。如果想查看开源项目或最新版本,可在GitHub上获得:github.com/alibaba/easy...

       为了方便和简化代码编写,这里同时引入了Lombok的依赖,后续代码中也会使用对应的wincmd源码注解。

       下面正式开始业务相关代码的编写。如果你想直接获得完整源码,对照源码阅读本篇文章,可在公号「程序新视界」内回“”获得完整源码。

       这里创建一个Member,会员的实体类,并在实体类中填写基础的个人信息。

       为了尽量多的演示EasyExcel的相关功能,在上述实体类中使用了其常见的一些注解:

       GenderConverter转换器的代码实现如下:

       不同版本中,convertToJavaData和convertToExcelData的方法参数有所不同,对应的变形源码值的获取方式也不同,大家在使用时注意对照自己的版本即可。

       为方便验证功能,DAO层的逻辑便不再实现,直接通过Service层来封装数据,先来看导出功能的业务类实现。

       定义MemberService接口:

       定义MemberServiceImpl实现类:

       其中数据采用模拟的静态数据,返回Member列表。

       在Controller层的实现一个简单的导出实现:

       这个实现方式非常简单直接,使用EasyExcel的write方法将查询到的数据进行处理,以流的形式写出即可。

       在浏览器访问对应的链接,可下载到如下Excel内容:

       如果我们需要将导出的Excel进行一些格式化的处理,这就需要用到导出策略的实现了。

       在EasyExcel执行write方法之后,获得ExcelWriterBuilder类,通过该类的registerWriteHandler方法可以设置一些处理策略。

       这里先实现一个通用的格式策略工具类CommonCellStyleStrategy:

       该类中示例设置了Excel的基础格式。

       再来实现一个精细化控制单元格内容CellWriteHandler的实现类:

       在这里,对单元格表头的第0个Cell设置了一个超链接。

       通过上面的定义两个策略实现,在导出Excel可以使用上述两个策略实现:

       通过浏览器,访问上述接口,导出的Excel格式如下:

       可以看出,导出的Excel已经附带了具体的格式。其中表头“用户名”上也携带了对应的超链接。其他更精细化的控制,大家可以在策略类中做进一步的控制。

       所谓的同步获取结果导入,就是执行导入操作时,将导入内容解析封装成一个结果列表返回给业务,业务代码再对列表中的数据进行集中的处理。

       先来看同步导入的实现方式。

       注意,在上述代码中,最终调用的是doReadSync()方法。

       这里直接用PostMan进行相应的文件上传请求:

       执行导入请求,会发现控制台打印出对应的解析对象:

       说明上传成功,并且解析成功。

       上面示例中是基于同步获取结果列表的形式进行导入,还有一种实现方式是基于监听器的形式来实现。这种形式可以达到边解析边处理业务逻辑的效果。

       定义Listener:

       在MemberExcelListener中可以针对每条数据进行对应的业务逻辑处理。

       对外接口实现如下:

       这里采用了doRead()方法进行读取操作。在PostMan中再次上传Excel,打印日志如下:

       说明解析成功,并且在解析的过程中,进行了业务逻辑的处理。

       本篇文章基于SpringBoot集成EasyExcel的实现展开,为大家讲解了EasyExcel在实践中的具体运用。大家可根据需要,进行变通处理。同时,基于自定义转换器、自定义策略、自定义监听器等形式达到灵活适用于各种场景。希望本篇文章能给大家带来帮助。

       博主简介:《SpringBoot技术内幕》技术图书作者,酷爱钻研技术,写技术干货文章。 公众号:「程序新视界」,博主的公众号,欢迎关注~ 技术交流:请联系博主微信号:zhuan2quan

@NoArgsConstructor, @RequiredArgsConstructor, @AllArgsConstructor

       ä¸“注于github, 有需要几千github star 出售多个github 账号, 需要联系V微信 eryuechanghe

        在Lombok中,生成构造方法的annotation一共有三个,@NoArgsConstructor, @RequiredArgsConstructor, @AllArgsContructor。使用这三个annotation来完成项目中对于不同构造方法的需求。

        @NoArgsConstructor : 生成一个无参数的构造方法,这个annotation在与其他的annotation配合起来使用的时候更加能凸显出他的重要性,例如在使用hibernate这种框架的时候,如果有一个有参数的构造方法的时候,NoArgsConstructor会展示出他的作用。

        @RequiredArgsConstructor: 会生成一个包含常量,和标识了NotNull的变量 的构造方法。生成的构造方法是private,如何想要对外提供使用可以使用staticName选项生成一个static方法。

        @AllArgsContructor: 会生成一个包含所有变量,同时如果变量使用了NotNull annotation , 会进行是否为空的校验, 我们来看一下官方给出的一个例子:

        使用了lombok

        未使用lombok

        @AllArgsConstructor 在生成的构造函数上会生成一@ConstructorProperties 的Java annotation, 当然也可以通过将suppressConstructorProperties 设置为true来禁用@ConstructorProperties 。 如果你知道@ConstructorProperties 是干什么用的,那么一定就知道@NoArgsConstructor为什么没有这个配置参数了。

        提示一点:@ConstructorProperties 只能用在JDK 6 中

搜索关键词:5050开发源码