有了它们,你再说开发慢,就该揍了

简介: 有了它们,你再说开发慢,就该揍了

设置对象属性

// 对象转map  
Map<String, String> map = BeanUtils.describe(user);  
System.out.println(map); // 输出 {"id":"1","name":"yideng"}  
// map转对象  
User newUser = new User();  
BeanUtils.populate(newUser, map);  
System.out.println(newUser); // 输出 {"id":1,"name":"yideng"}  
User user = new User();  
BeanUtils.setProperty(user, "id", 1);  
BeanUtils.setProperty(user, "name", "yideng");  
System.out.println(BeanUtils.getProperty(user, "name")); // 输出 yideng  
System.out.println(user); // 输出 {"id":1,"name":"yideng"}  

对象和map互转

// 对象转map  
Map<String, String> map = BeanUtils.describe(user);  
System.out.println(map); // 输出 {"id":"1","name":"yideng"}  
// map转对象  
User newUser = new User();  
BeanUtils.populate(newUser, map);  
System.out.println(newUser); // 输出 {"id":1,"name":"yideng"}  

2.4 commons-io 文件流处理

Maven依赖:

<dependency>  
    <groupId>commons-io</groupId>  
    <artifactId>commons-io</artifactId>  
    <version>2.8.0</version>  
</dependency>  

文件处理

File file = new File("demo1.txt");  
// 读取文件  
List<String> lines = FileUtils.readLines(file, Charset.defaultCharset());  
// 写入文件  
FileUtils.writeLines(new File("demo2.txt"), lines);  
// 复制文件  
FileUtils.copyFile(srcFile, destFile);  

3. Google Guava 工具类库

Maven依赖:

<dependency>  
    <groupId>com.google.guava</groupId>  
    <artifactId>guava</artifactId>  
    <version>30.1.1-jre</version>  
</dependency>  

3.1 创建集合

List<String> list = Lists.newArrayList();  
List<Integer> list = Lists.newArrayList(1, 2, 3);  
// 反转list  
List<Integer> reverse = Lists.reverse(list);  
System.out.println(reverse); // 输出 [3, 2, 1]  
// list集合元素太多,可以分成若干个集合,每个集合10个元素  
List<List<Integer>> partition = Lists.partition(list, 10);  
Map<String, String> map = Maps.newHashMap();  
Set<String> set = Sets.newHashSet();  

3.2 黑科技集合

3.2.1 Multimap 一个key可以映射多个value的HashMap

Multimap<String, Integer> map = ArrayListMultimap.create();  
map.put("key", 1);  
map.put("key", 2);  
Collection<Integer> values = map.get("key");  
System.out.println(map); // 输出 {"key":[1,2]}  
// 还能返回你以前使用的臃肿的Map  
Map<String, Collection<Integer>> collectionMap = map.asMap();  

多省事,多简洁,省得你再创建 Map<String, List>

3.2.2 BiMap 一种连value也不能重复的HashMap

BiMap<String, String> biMap = HashBiMap.create();  
// 如果value重复,put方法会抛异常,除非用forcePut方法  
biMap.put("key","value");  
System.out.println(biMap); // 输出 {"key":"value"}  
// 既然value不能重复,何不实现个翻转key/value的方法,已经有了  
BiMap<String, String> inverse = biMap.inverse();  
System.out.println(inverse); // 输出 {"value":"key"}  

这其实是双向映射,在某些场景还是很实用的。

3.2.3 Table 一种有两个key的HashMap

// 一批用户,同时按年龄和性别分组  
Table<Integer, String, String> table = HashBasedTable.create();  
table.put(18, "男", "yideng");  
table.put(18, "女", "Lily");  
System.out.println(table.get(18, "男")); // 输出 yideng  
// 这其实是一个二维的Map,可以查看行数据  
Map<String, String> row = table.row(18);  
System.out.println(row); // 输出 {"男":"yideng","女":"Lily"}  
// 查看列数据  
Map<Integer, String> column = table.column("男");  
System.out.println(column); // 输出 {18:"yideng"}  

3.2.4 Multiset 一种用来计数的Set

Multiset<String> multiset = HashMultiset.create();  
multiset.add("apple");  
multiset.add("apple");  
multiset.add("orange");  
System.out.println(multiset.count("apple")); // 输出 2  
// 查看去重的元素  
Set<String> set = multiset.elementSet();  
System.out.println(set); // 输出 ["orange","apple"]  
// 还能查看没有去重的元素  
Iterator<String> iterator = multiset.iterator();  
while (iterator.hasNext()) {  
    System.out.println(iterator.next());  
}  
// 还能手动设置某个元素出现的次数  
multiset.setCount("apple", 5);

以上为个人经验,希望能给大家一个参考,如有错误或未考虑完全的地方,望不吝赐教。

转自: 一灯架构

链接:www.toutiao.com/i6943239541448917512

目录
相关文章
|
4月前
|
SQL 分布式计算 运维
如何对付一个耗时6h+的ODPS任务:慢节点优化实践
本文描述了大数据处理任务(特别是涉及大量JOIN操作的任务)中遇到的性能瓶颈问题及其优化过程。
|
Java Android开发
|
8月前
|
缓存 NoSQL 数据库
记录线上数据库飙升到60%的性能优化
有一天,dba在数据库告警群找到我,说我们数据库CPU有规律性的尖刺,qps每次突然增加500+,尖刺时cpu飙升到60%,没尖刺时只有5%左右
记录线上数据库飙升到60%的性能优化
|
8月前
|
缓存 JavaScript 前端开发
服务器反应慢如何解决?
通常来说,访问者会在最初的几秒钟内决定是留在您的网站还是离开。如果页面加载时间超过五秒,访问者离开的可能性就会增加 90%。所以,作为站长们,必须减少服务器响应时间,以确保其网站加载速度更快。以下是减少网站服务器响应时间的几种简单方式。
149 19
|
8月前
|
存储 SQL Java
jvm性能调优实战 - 27亿级数据量的实时分析引擎,为啥频繁发生Full GC
jvm性能调优实战 - 27亿级数据量的实时分析引擎,为啥频繁发生Full GC
107 0
|
SQL 监控 关系型数据库
腾讯一面:你平时怎么排查并调优慢 SQL 的
腾讯一面:你平时怎么排查并调优慢 SQL 的
129 0
|
SQL Arthas druid
MyBtais 批量插入慢排查及分析(后续)
MyBtais 批量插入慢排查及分析(后续)
193 0
|
开发工具 开发者
慢与快
我经常跟我的学员这样说:对于学习做游戏这件事情,大家要放平心态,不用着急,我给大家提供一年时间的服务,所以你大可以慢慢来。如果你的时间充足的话,就制定一个为期较短的计划。如果你工作比较忙,时间不够的话,那么就制定一个比较宽松的计划。最重要的是不要停,不要半途而废,不要就此放下。想一下,如果你能够在一年的时间里学会并掌握一门新技能,那也是相当不错的了。
84 0
|
SQL 缓存 固态存储
线上MySQL频繁抖动的性能优化实战
平时执行的更新语句,都是从磁盘上加载数据页到DB内存的缓存页,接着就直接更新内存里的缓存页,同时还更新对应的redo log写入一个buffer中。
226 0
|
SQL 负载均衡 关系型数据库
Java开发 - 如何进行慢sql优化
Java开发 - 如何进行慢sql优化
285 0