本篇仅作为个人笔记,从各处总结儿来。
(1)stream
Stream(流)是一个来自数据源的元素队列并支持聚合操作
-
stream() − 为集合创建串行流。
-
parallelStream() − 为集合创建并行流
---Stream 提供了新的方法 'forEach' 来迭代流中的每个数据。以下代码片段使用 forEach 输出了10个随机数:
---map 方法用于映射每个元素到对应的结果,以下代码片段使用 map 输出了元素对应的平方数:
List<Integer> numbers = Arrays.asList(3, 2, 2, 3, 7, 3, 5); // 获取对应的平方数 List<Integer> squaresList = numbers.stream().map( i -> i*i).distinct().collect(Collectors.toList());
---filter 方法用于通过设置的条件过滤出元素。
---limit 方法用于获取指定数量的流。 以下代码片段使用 limit 方法打印出 10 条数据:
Random random = new Random(); random.ints().limit(10).forEach(System.out::println);
---sorted 方法用于对流进行排序。
---parallelStream 是流并行处理程序的代替方法。以下实例我们使用 parallelStream 来输出空字符串的数量:
List<String> strings = Arrays.asList("abc", "", "bc", "efg", "abcd","", "jkl"); // 获取空字符串的数量 long count = strings.parallelStream().filter(string -> string.isEmpty()).count();
---Collectors 类实现了很多归约操作,例如将流转换成集合和聚合元素。Collectors 可用于返回列表或字符串:
List<String>strings = Arrays.asList("abc", "", "bc", "efg", "abcd","", "jkl"); List<String> filtered = strings.stream().filter(string -> !string.isEmpty()).collect(Collectors.toList());
(2)cachebuilder
解决本地缓存
LoadingCache和Cache的实例的builder拥有下列中至少一个feature:
自动从缓存中加载键值对
当缓存中达到了最大存储数量时,会首先从缓存中删除使用频数最少的那些键值对
对键值对进行基于时间维度的过期验证,具体时间从上次access或写入算起
键值都会自动用 weak reference(https://docs.oracle.com/javase/7/docs/api/java/lang/ref/WeakReference.html?is-external=true) 进行包装
value值会自动用weak reference或者soft reference进行包装
当键值对要淘汰时会提醒
可以对缓存的access统计量进行累积
(3)ImmutableList
ImmutableList<T>.Add(T) 方法
将指定的对象添加到不可变列表末尾。
public System.Collections.Immutable.ImmutableList<T> Add (T value);
(4)访问数据库的传统方法
访问数据库的传统方法
传统访问数据库的方法非常面向过程,分为以下几步
– 实例化connection
– 实例化statement
– 通过statement的参数sql语句访问数据库,返回数据进行处理