[Java]合理封装第三方工具包(附视频)
-1.视频链接
视频版: 视频版会对本文章内容进行详细解释
[Java]合理封装第三方工具包_哔哩哔哩_bilibili
0.核心思想
对第三方工具方法进行封装,使其本地化,降低记忆和使用成本
1.背景
在我们的项目中,通常会引用一些第三方工具包,或者是使用jdk自带的一些工具类
例如:
commons-lang3 apache开源工具类库
fastjson 阿里开源操作Json的工具类库
Objects JDK自带的object对象工具类
File JDK自带的file文件处理类
hutool-all 国内优秀简洁的开源类库
<dependency><groupId>org.apache.commons</groupId><artifactId>commons-lang3</artifactId>
</dependency>
<dependency><groupId>com.alibaba</groupId><artifactId>fastjson</artifactId>
</dependency>
<dependency><groupId>cn.hutool</groupId><artifactId>hutool-all</artifactId>
</dependency>
但是这些工具类库有一个很不好的点,就是需要学习成本,需要记住各种Api方法的名称
比如:
String.valueOf() LocalDateTime.parse() Json.from() CollUtil.isEmpty() ....
因此我们需要合理的对这些第三方进行本地化
比如封装fastJson为JsonHelper
比如封装File为FileHelper
比如封装Objects为ObjectHelper
2.封装思想
1.统一风格的方法命名
比如转换数据类型的方法 全部是叫:"to"
2.工具方法的归属
有2种分类方式
第一种分类方式就是根据对象来分类 比如我们想要对String相关的工具方法本地化封装 那么应该把这些封装好的方法 归属到StringHelper中
第二种分类方式是根据行为来分类 比如我们想要封装所有check类型的方法 比如isBlank isEmpty() isNotNull()这种方法 那么我们就要单独定义一个CheckHelper类来存储这些方法
3.为什么叫helper而不是叫utils
因为utils是独立的一个工具类,而helper代表是一整个相关体系,它的后续扩展性更好,比如FileHelper,会搭配更多的file类 比如FileType MyFileSql