Java 学习(一)

本篇仅作为个人笔记,从各处总结儿来。

(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语句访问数据库,返回数据进行处理

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值