Java 中节省 90% 时间的常用的工具类
Java的多线程编程需理解锁和并发工具类 #生活技巧# #工作学习技巧# #编程语言学习路径#
Map<String, String> arrayMap = (HashMap) ArrayUtils.toMap(new String[][]{
{“key1”, “value1”}, {“key2”, “value2”}
});
for (String s : arrayMap.keySet()) {
System.out.println(arrayMap.get(s));
}
}
输出结果:
array3:{value1,value2,value3,value4}
array4:{value1,value2,value3,value4}
true
array4反转后:{value4,value3,value2,value1}
value1
value2
Process finished with exit code 0
EnumUtils 枚举操作getEnum(Class enumClass, String enumName) 通过类返回一个枚举,可能返回空;
getEnumList(Class enumClass) 通过类返回一个枚举集合;
getEnumMap(Class enumClass) 通过类返回一个枚举map;
isValidEnum(Class enumClass, String enumName) 验证enumName是否在枚举中,返回true或false。
public enum ImagesTypeEnum {
JPG,JPEG,PNG,GIF;
}
public static void main(String[] args) {
ImagesTypeEnum imagesTypeEnum = EnumUtils.getEnum(ImagesTypeEnum.class, “JPG”);
System.out.println("imagesTypeEnum = " + imagesTypeEnum);
System.out.println(“--------------”);
List imagesTypeEnumList = EnumUtils.getEnumList(ImagesTypeEnum.class);
imagesTypeEnumList.stream().forEach(
imagesTypeEnum1 -> System.out.println("imagesTypeEnum1 = " + imagesTypeEnum1)
);
System.out.println(“--------------”);
Map<String, ImagesTypeEnum> imagesTypeEnumMap = EnumUtils.getEnumMap(ImagesTypeEnum.class);
imagesTypeEnumMap.forEach((k, v) -> System.out.println(“key:” + k + “,value:” + v));
System.out.println(“-------------”);
boolean result = EnumUtils.isValidEnum(ImagesTypeEnum.class, “JPG”);
System.out.println("result = " + result);
boolean result1 = EnumUtils.isValidEnum(ImagesTypeEnum.class, null);
System.out.println("result1 = " + result1);
}
输出结果:
imagesTypeEnum = JPG
imagesTypeEnum1 = JPG
imagesTypeEnum1 = JPEG
imagesTypeEnum1 = PNG
imagesTypeEnum1 = GIF
key:JPG,value:JPG
key:JPEG,value:JPEG
key:PNG,value:PNG
key:GIF,value:GIF
result = true
result1 = false
Process finished with exit code 0
collections4 集合操作commons-collections4 增强了 Java 集合框架,提供了一系列简单的 API 方便操作集合。
maven 依赖
org.apache.commons
commons-collections4
4.4
CollectionUtils 工具类这是一个工具类,可以检查 null 元素不被加入集合,合并列表,过滤列表,两个列表的并集、差集、合集。有部分功能在 Java 8 中可以被 Stream API 替换。
public static void main(String[] args) {
//null 元素不能加进去
List arrayList1 = new ArrayList<>();
arrayList1.add(“a”);
CollectionUtils.addIgnoreNull(arrayList1, null);
System.out.println(arrayList1.size());
//排好序的集合,合并后还是排序的
List arrayList2 = new ArrayList<>();
arrayList2.add(“a”);
arrayList2.add(“b”);
List arrayList3 = new ArrayList<>();
arrayList3.add(“c”);
arrayList3.add(“d”);
System.out.println(“arrayList3:” + arrayList3);
List arrayList4 = CollectionUtils.collate(arrayList2, arrayList3);
System.out.println(“arrayList4:” + arrayList4);
//交集
Collection strings = CollectionUtils.retainAll(arrayList4, arrayList3);
System.out.println(“arrayList3和arrayList4的交集:” + strings);
//并集
Collection union = CollectionUtils.union(arrayList4, arrayList3);
System.out.println(“arrayList3和arrayList4的并集:” + union);
//差集
Collection subtract = CollectionUtils.subtract(arrayList4, arrayList3);
System.out.println(“arrayList3和arrayList4的差集:” + subtract);
// 过滤,只保留 b
CollectionUtils.filter(arrayList4, s -> s.equals(“b”));
System.out.println(arrayList4);
}
输出结果:
1
arrayList3:[c, d]
arrayList4:[a, b, c, d]
arrayList3和arrayList4的交集:[c, d]
arrayList3和arrayList4的并集:[a, b, c, d]
arrayList3和arrayList4的差集:[a, b]
[b]
Process finished with exit code 0
Bag 统计次数用于统计值在集合中出现的次数。
public static void main(String[] args) {
Bag bag = new HashBag();
bag.add(“a”);
bag.add(“b”);
bag.add(“a”);
bag.add(“c”, 3);
System.out.println(bag);
System.out.println(bag.getCount(“c”));
}
输出结果:
[2:a,1:b,3:c]
3
Process finished with exit code 0
beanutils Bean 操作beanutils 是通过反射机制对 JavaBean 进行操作的。比如对 Bean 进行复制、map 转对象、对象转 Map。
maven 依赖
commons-beanutils
commons-beanutils
1.9.4
public class User {
private String name;
public String getName() {
return name;
}
public void setName(String name) {
this.name = name;
}
}
public static void main(String[] args) throws Exception {
User user1 = new User();
user1.setName(“李四”);
User user2 = (User) BeanUtils.cloneBean(user1);
System.out.println(user2.getName());
//User 转 map
Map<String, String> describe = BeanUtils.describe(user1);
System.out.println(describe);
//Map 转 User
Map<String, String> beanMap = new HashMap();
beanMap.put(“name”, “张三”);
User user3 = new User();
BeanUtils.populate(user3, beanMap);
System.out.println(user3.getName());
}
输出结果:
李四
{name=李四}
张三
Process finished with exit code 0
Guava
Google 开源的一个基于 Java 扩展项目,包含了一些基本工具、集合扩展、缓存、并发工具包、字符串处理等。
maven 依赖
com.google.guava
guava
30.1.1-jre
Map<String, List> 类型在java 代码中经常会遇到需要写 Map<String, List> map 的局部变量的时候。有时候业务情况还会更复杂一点。
public static void main(String[] args) {
//以前
Map<String, List> map = new HashMap<>();
List list = new ArrayList<>();
list.add(“张三”);
list.add(“李四”);
map.put(“名称”, list);
System.out.println(map.get(“名称”));
//现在
Multimap<String, String> multimap = ArrayListMultimap.create();
multimap.put(“名称”, “张三”);
multimap.put(“名称”, “李四”);
System.out.println(multimap.get(“名称”));
}
输出结果:
[张三, 李四]
[张三, 李四]
Process finished with exit code 0
value 不能重复的 Map在 Map 中 value 的值时可以重复的,Guava 可以创建一个 value 不可重复的 Map,并且 Map 和 value 可以对调。
public static void main(String[] args) {
//会报异常
BiMap<String ,String> biMap = HashBiMap.create();
biMap.put(“key1”, “value”);
biMap.put(“key2”, “value”);
System.out.println(biMap.get(“key1”));
}
输出结果:
Exception in thread “main” java.lang.IllegalArgumentException: value already present: value
at com.google.common.collect.HashBiMap.put(HashBiMap.java:287)
at com.google.common.collect.HashBiMap.put(HashBiMap.java:262)
at org.example.clone.Test.main(Test.java:17)
Process finished with exit code 1
public static void main(String[] args) {
BiMap<String ,String> biMap = HashBiMap.create();
biMap.put(“key1”, “value1”);
biMap.put(“key2”, “value2”);
System.out.println(biMap.get(“key1”));
//key-value 对调
biMap = biMap.inverse();
System.out.println(biMap.get(“value1”));
}
输出结果:
value1
key1
Process finished with exit code 0
Guava cache写业务的时候肯定会使用缓存,当不想用第三方作为缓存的时候,Map 又不够强大,就可以使用 Guava 的缓存。
缓存的并发级别Guava提供了设置并发级别的API,使得缓存支持并发的写入和读取。与ConcurrentHashMap类似,Guava cache的并发也是通过分离锁实现。在通常情况下,推荐将并发级别设置为服务器cpu核心数。
CacheBuilder.newBuilder()
// 设置并发级别为cpu核心数,默认为4
.concurrencyLevel(Runtime.getRuntime().availableProcessors())
.build();
缓存的初始容量设置我们在构建缓存时可以为缓存设置一个合理大小初始容量,由于Guava的缓存使用了分离锁的机制,扩容的代价非常昂贵。所以合理的初始容量能够减少缓存容器的扩容次数。
CacheBuilder.newBuilder()
// 设置初始容量为100
.initialCapacity(100)
.build();
设置最大存储Guava Cache可以在构建缓存对象时指定缓存所能够存储的最大记录数量。当Cache中的记录数量达到最大值后再调用put方法向其中添加对象,Guava会先从当前缓存的对象记录中选择一条删除掉,腾出空间后再将新的对象存储到Cache中。
public static void main(String[] args) {
Cache<String, String> cache = CacheBuilder.newBuilder().maximumSize(2).build();
cache.put(“key1”, “value1”);
cache.put(“key2”, “value2”);
cache.put(“key3”, “value3”);
System.out.println(cache.getIfPresent(“key1”)); //key1 = null
}
输出结果:
null
Process finished with exit code 0
过期时间expireAfterAccess() 可以设置缓存的过期时间。
public static void main(String[] args) throws InterruptedException {
//设置过期时间为2秒
Cache<String, String> cache1 = CacheBuilder.newBuilder().maximumSize(2).expireAfterAccess(2, TimeUnit.SECONDS).build();
cache1.put(“key1”, “value1”);
Thread.sleep(1000);
System.out.println(cache1.getIfPresent(“key1”));
Thread.sleep(2000);
System.out.println(cache1.getIfPresent(“key1”));
}
输出结果:
value1
null
Process finished with exit code 0
LoadingCache使用自定义ClassLoader加载数据,置入内存中。从LoadingCache中获取数据时,若数据存在则直接返回;若数据不存在,则根据ClassLoader的load方法加载数据至内存,然后返回该数据。
public class Test {
public static void main(String[] args) throws Exception {
System.out.println(numCache.get(1));
Thread.sleep(1000);
System.out.println(numCache.get(1));
Thread.sleep(1000);
numCache.put(1, 6);
System.out.println(numCache.get(1));
}
private static LoadingCache<Integer, Integer> numCache = CacheBuilder.newBuilder().
最后
自我介绍一下,小编13年上海交大毕业,曾经在小公司待过,也去过华为、OPPO等大厂,18年进入阿里一直到现在。
深知大多数Java工程师,想要提升技能,往往是自己摸索成长,自己不成体系的自学效果低效漫长且无助。
因此收集整理了一份《2024年Java开发全套学习资料》,初衷也很简单,就是希望能够帮助到想自学提升又不知道该从何学起的朋友,同时减轻大家的负担。
既有适合小白学习的零基础资料,也有适合3年以上经验的小伙伴深入学习提升的进阶课程,基本涵盖了95%以上Java开发知识点,不论你是刚入门Java开发的新手,还是希望在技术上不断提升的资深开发者,这些资料都将为你打开新的学习之门!
如果你觉得这些内容对你有帮助,需要这份全套学习资料的朋友可以戳我获取!!
由于文件比较大,这里只是将部分目录截图出来,每个节点里面都包含大厂面经、学习笔记、源码讲义、实战项目、讲解视频,并且会持续更新!
.out.println(numCache.get(1));
Thread.sleep(1000);
numCache.put(1, 6);
System.out.println(numCache.get(1));
}
private static LoadingCache<Integer, Integer> numCache = CacheBuilder.newBuilder().
最后
自我介绍一下,小编13年上海交大毕业,曾经在小公司待过,也去过华为、OPPO等大厂,18年进入阿里一直到现在。
深知大多数Java工程师,想要提升技能,往往是自己摸索成长,自己不成体系的自学效果低效漫长且无助。
因此收集整理了一份《2024年Java开发全套学习资料》,初衷也很简单,就是希望能够帮助到想自学提升又不知道该从何学起的朋友,同时减轻大家的负担。
[外链图片转存中…(img-ImcKecBd-1715703230272)]
[外链图片转存中…(img-heBRK6eW-1715703230273)]
[外链图片转存中…(img-aBWlSsyR-1715703230273)]
既有适合小白学习的零基础资料,也有适合3年以上经验的小伙伴深入学习提升的进阶课程,基本涵盖了95%以上Java开发知识点,不论你是刚入门Java开发的新手,还是希望在技术上不断提升的资深开发者,这些资料都将为你打开新的学习之门!
如果你觉得这些内容对你有帮助,需要这份全套学习资料的朋友可以戳我获取!!
由于文件比较大,这里只是将部分目录截图出来,每个节点里面都包含大厂面经、学习笔记、源码讲义、实战项目、讲解视频,并且会持续更新!
网址:Java 中节省 90% 时间的常用的工具类 https://www.yuejiaxmz.com/news/view/509030
相关内容
JAVA常用工具Java中String和byte[]间的转换
java基础学习十四之BigDecimal类与常用日期时间类
17个可以节省你时间的CSS工具
在生活中工作中可能会为你省钱、节省时间的工具
Android操作系统中的日程管理:用Java编写高效时间规划应用
别找了,最全的10类常用软件测试工具全都在这!(共60+款工具)
【JAVA】Java高级:Java中的常用设计模式——设计模式的基本思想与应用场景
有哪些流行的Java压力测试工具
Java 在生活中的 10 大应用