百度360必应搜狗淘宝本站头条
当前位置:网站首页 > 编程网 > 正文

Java世界最常用的工具类库

yuyutoo 2024-11-18 18:58 3 浏览 0 评论

Apache Commons

Apache Commons有很多子项目,常用的项目如下

@Data

public class User {

 private String username;

 private String password;

}

设置和获得属性

User user = new User();

BeanUtils.setProperty(user, "username", "li");

BeanUtils.getProperty(user, "username");

map和bean的互相转换

// bean->map

Map<String, String> map = BeanUtils.describe(user);

// map->bean

BeanUtils.populate(user, map);

我们将对象放在缓存中通常用redis中的hash,如下

# 设置用户信息

hset student name test

hset student age 10

这种场景下map和bean的互相转换的工具类就特别有用

Codec

常见的编码,解码方法封装

// Base64

Base64.encodeBase64String(byte[] binaryData)

Base64.decodeBase64(String base64String)

// MD5

DigestUtils.md5Hex(String data)

// URL

URLCodec.decodeUrl(byte[] bytes);

URLCodec.encodeUrl(BitSet urlsafe, byte[] bytes);

Collections

交并差等操作

// 判空

CollectionUtils.isEmpty(collA);

// 交集

CollectionUtils.retainAll(collA, collB);

// 并集

CollectionUtils.union(collA, collB);

// 差集

CollectionUtils.subtract(collA, collB);

// 判等

CollectionUtils.isEqualCollection(collA, collB);

I/O

IOUtils对IO操作的封装

// 拷贝流

IOUtils.copy(InputStream input, OutputStream output);

// 从流中读取内容,转为list

List<String> line = IOUtils.readLines(InputStream input, Charset encoding);

FileUtils对文件操作类的封装

File file = new File("/show/data.text");

// 按行读取文件

List<String> lines = FileUtils.readLines(file, "UTF-8");

// 将字符串写入文件

FileUtils.writeStringToFile(file, "test", "UTF-8");

// 文件复制

FileUtils.copyFile(srcFile, destFile);

Lang

StringUtils 以下断言测试通过

// isEmpty的实现 cs == null || cs.length() == 0; return true

assertEquals(true, StringUtils.isEmpty(""));

assertEquals(true, StringUtils.isBlank(null));

assertEquals(true, StringUtils.isBlank(""));

// 空格

assertEquals(true, StringUtils.isBlank(" "));

// 回车

assertEquals(true, StringUtils.isBlank(" "));

Pair和Triple

当想返回2个或3个值,但这几个值没有相关性,没有必要单独封装一个对象,就可以用到如下数据结构,返回Pair或Triple对象

Google Guava

集合的创建

// 普通集合的创建

List<String> list = Lists.newArrayList();

Set<String> set = Sets.newHashSet();

// 不可变集合的创建

ImmutableList<String> list = ImmutableList.of("a", "b", "c");

ImmutableSet<String> set = ImmutableSet.of("a", "b");

不可变集合是线程安全的,并且中途不可改变,因为add等方法是被声明为过期,并且会抛出异常

public final void add(int index, E element) {

	throw new UnsupportedOperationException();

}

各种黑科技集合

// use java

Map<String, List<Integer>> map = new HashMap<String, List<Integer>>();

// use guava

Multimap<String, Integer> map = ArrayListMultimap.create();

map.put("key1", 1);

map.put("key1", 2);

// [1, 2]

System.out.println(map.get("key1"));

2个键映射一个值

Table<String, String, Integer> table = HashBasedTable.create();

table.put("a", "a", 1);

table.put("a", "b", 2);

// 2

System.out.println(table.get("a", "b"));

还有很多其他各种类型的集合,不再介绍

stop watch

查看某段代码的运行时间

Stopwatch stopwatch = Stopwatch.createStarted();

// do something

long second = stopwatch.elapsed(TimeUnit.SECONDS);

TimeUnit 可以指定时间精度

Joda Time

jdk1.8之前,日期操作类常用的只有java.util.Date和java.util.Calendar,但是这2个类的易用性实在太差了,SimpleDateFormat不是线程安全的 。这就逼迫用户去选择第三方的日期操作类,Joda Time就是其中的佼佼者。后来Java自身也意识到了这个问题,于是jdk1.8大量借鉴了Joda Time的理念,推出了新的日期api,LocalDate,LocalTime,LocalDateTime等,可以看如下文章了解一下用法、

https://blog.csdn.net/zzti_erlie/article/details/100849192

2者的api很相似,如果公司的jdk版本在1.8以上推荐使用jdk1.8新推出的日期类,如果在1.8以下推荐使用Joda Time

Apache Httpcomponents

很多http工具类都是用Apache Httpcomponents封装的,内容比较多,单开一篇文章把

相关推荐

MySQL中的数据类型(mysql数据类型有哪些,并举例)

MySQL中的数据类型...

mysql窗口函数over中rows_MySQL窗口函数

下面的讲解将基于这个employee2表:mysql>SELECT*FROMemployee2;+----+-----------+------+---------+---------...

别再说你精通数据库,MySQL的设计和列类型选取真的很有讲究

总想写一篇MySQL的设计和列类型选取的文章,一直挤不出时间。天天晚上都要加班,正逢5.1放假,抽了几天就有了此文。如果对朋友们能有帮助的话,关注一波不过分吧?求关!选择更优的数据类型尽量选择存储空间...

MySQL数据库知识(mysql数据库相关知识)

MySQL是一种关系型数据库管理系统;那废话不多说,直接上自己以前学习整理文档:查看数据库命令:(1).查看存储过程状态:showprocedurestatus;(2).显示系统变量:show...

数据库:MySQL 高性能优化规范建议

数据库命令规范所有数据库对象名称必须使用小写字母并用下划线分割所有数据库对象名称禁止使用MySQL保留关键字(如果表名中包含关键字查询时,需要将其用单引号括起来)数据库对象的命名要能做到见名识意,...

MySQL实战——表结构设计之数字类型

整型不建议刻意去用unsigned属性,因为在做一些数据分析时,SQL可能返回的结果并不是想要得到的结果。比如在财务的场景下,经常会做一些加减操作。MySQL要求unsigned数值相减之...

MySQL数据库入门(四)数据类型简介

在MySQL中数据类型有以下五种:数字整数:常用的有2种,一是int型,int型最多可以表示10位数字(无符号的4开头,有符号的2开头;二是tinyintunsigned,用来表示年龄(值范围是0-...

mysql常用语句超级详细汇总(mysql常用语法)

1.连接数据库:连接本地数据库:mysql-uroot-p连接远程数据库:mysql-h192.169.22.199-uroot-p退出数据库:exit...

MYSQL——CAST()函数的用法(mysql中case)

语法为:Cast(字段名as转换的类型),其中类型可以为:CHAR[(N)]字符型DATE日期型DATETIME日期和时间型...

MySQL存储引擎背后的真相:为何InnoDB并非所有场景的最佳选择

MySQL存储引擎背后的真相:为何InnoDB并非所有场景的最佳选择引言部分你是否遇到过这样的情况:明明已经按照最佳实践选择了MySQL的InnoDB引擎,却发现某些查询依然缓慢得令人沮丧?或者当你的...

MySQL 表分区?涨知识了(mysql数据表分区)

1.什么是表分区...

《MySQL必知必会》_笔记08(mysql必知必会mobi)

第19章插入数据一、数据插入概述INSERT语句用于向数据库表中插入(添加)数据,是SQL中常用的数据操作语句之一。它可以用多种方式使用,包括插入完整的行、插入行的一部分、插入多行以及插入某些查询的...

当 SQL Server(mssql-jdbc) 遇上 BigDecimal → 精度丢失,真坑!

开心一刻  中午和哥们一起喝茶  哥们说道:晚上喝酒去啊...

MYSQL有哪些数据类型(mysql有哪些数据类型,有哪些运算符)

整理下以便查阅,还想吐槽下:这头条怎么就不能给文章分类呢?整数类型...

使用MySQL分区的注意事项(使用mysql分区的注意事项有哪些)

MySQL分区是将一个表分解成多个区块进行操作和保存,从而降低每次操作的数据量,提高性能。从逻辑上看,只有一个表,但物理上这个表可能由多个物理分区组成,每个分区都是一个独立的对象,可以进行独立处理。...

取消回复欢迎 发表评论: