èè使ç¨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的源码iapp滑动源码情况,导致整个服务不可用。源码后续逐步转移到EasyExcel,源码简直不能太好用了。源码
EasyExcel是源码阿里巴巴开源插件之一,主要解决了poi框架使用复杂,源码sax解析模式不容易操作,源码重新关联源码数据量大起来容易OOM,源码解决了POI并发造成的源码报错。主要解决方式:通过解压文件的源码方式加载,一行一行地加载,并且抛弃样式字体等不重要的数据,降低内存的占用。
在之前专门写过一篇文章《EasyExcel太方便易用了,强烈推荐!》,介绍EasyExcel功能的基本使用。今天这篇文章,cpu z源码我们基于SpringBoot来实现一下EasyExcel的集成,更加方便大家在实践中的直接使用。
创建一个基础的SpringBoot项目,比如这里采用SpringBoot 2.7.2版本。
EasyExcel在SpringBoot的集成非常方便,只需引入对应的pom依赖即可。在上述dependencies中添加EasyExcel的依赖:
EasyExcel目前稳定最新版本2.2.。如果想查看开源项目或最新版本,可在GitHub上获得:github.com/alibaba/easy...
为了方便和简化代码编写,这里同时引入了Lombok的依赖,后续代码中也会使用对应的源码公式算法注解。
下面正式开始业务相关代码的编写。如果你想直接获得完整源码,对照源码阅读本篇文章,可在公号「程序新视界」内回“”获得完整源码。
这里创建一个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 ä¸
2025-01-24 10:37
2025-01-24 10:01
2025-01-24 09:12
2025-01-24 09:06
2025-01-24 08:38