JDK8的几个方便快捷小知识
阿粉相信,个方JDK8 现在已经是便快非常普及的了,现在几乎百分之七十以上的知识公司都已经在使用了,虽然大部分的个方公司都换上了 JDK8 但是对于编码习惯来说,依然能够看到很多属于可以优化的便快代码,毕竟使用JDK8 进行编码的知识话,会让自己的个方代码看起来很优雅。阿粉今天就来看看 JDK7 和 JDK8 中的便快一些可以"优化"的代码。
JDK8 的知识 fro 循环
既然要说for循环,那么没有对比就没有伤害,个方我们来对比一下使用 JDK7 的便快 for 循环和使用 JDK8 的 for 循环。
获取List中所有人员的知识ID获取值之前我们先给原始的 List 进行赋值:
private static List
User user = new User();
user.setId(UuidUtil.genLmnId());
user.setName("张三");
user.setAge(20);
user.setDeptName("开发部");
List
list.add(user);
User user2 = new User();
user2.setId(UuidUtil.genLmnId());
user2.setName("李四");
user2.setAge(21);
user2.setDeptName("财务部");
list.add(user2);
User user3 = new User();
user3.setId(UuidUtil.genLmnId());
user3.setName("王五");
user3.setAge(22);
user3.setDeptName("运维部");
list.add(user3);
return list;
}一会我们直接调用就可以了,User对象很简单:
@Data
class User{
private String id;
private String name;
private Integer age;
private String deptName;
}JDK7获取List中的个方Id数据:
//给List赋值
List
//新的IdList
List
for (User user: list) {
Ids.add(user.getId());
}JDK8 获取Id数据:
List
这个时候就有的人会说,这算啥,便快就这点代码?知识
获取List数据中年龄大于等于21的站群服务器人传统做法,不用想,直接遍历,遍历之后,判断一下年龄是否是大于21,然后加入到新的对象中。这想法没错,那么我们来试试。
//给List赋值
List
//新的list
List
for (User user: list) {
if (user.getAge() >= 21){
newList.add(user);
}
}
System.out.println("JDK7的获取数据==="+JSON.toJSON(newList));结果是对的,能准确筛选出我们要的数据:
JDK7的获取数据===[{ "deptName":"财务部","name":"李四","id":"165001403518349849","age":21},{ "deptName":"运维部","name":"王五","id":"165001403518375639","age":22}]
JDK8 怎么实现?那就是filter,代码来看看:
List
我们看看数据:
JDK8的获取数据===[{ "deptName":"财务部","name":"李四","id":"165001458145431986","age":21},{ "deptName":"运维部","name":"王五","id":"165001458145466505","age":22}]这个筛选,那是非常的方便,虽然内部还是循环,但是至少让我们在写代码的时候,把写循环这一块的内容直接给省略掉了,不用再继续的云服务器去自己去写循环,是不是就很便利的给自己省下了一大堆的时间。
接下来我们再给User里面放一个运维部的数据:
User user4 = new User();
user4.setId(UuidUtil.genLmnId());
user4.setName("赵六");
user4.setAge(22);
user4.setDeptName("运维部");
list.add(user4);这时候,我们没从数据库端进行数据的分组,可能有时候同一个接口要给很多服务去调用,但是我们又不能为了因为数据格式要求不一致,就重新在写一段相同的逻辑代码,只能说是根据某些参数的不同,处理一下返回值,这时候就用到另外测操作了。
按照部门返回不同部门下的人员的数据如果我们要用SQL,那很简单,根据部门分组,如果要是在代码里面呢?就用我们最简单的User来进行分组。
JDK8 直接简单方便:
Map<String, List<User>> collect = list.stream().collect(Collectors.groupingBy(User::getDeptName));我们看看返回的数据:
JDK8的获取数据==={
"开发部":[{ "deptName":"开发部","name":"张三","id":"165035610923271907","age":20}],
"财务部":[{ "deptName":"财务部","name":"李四","id":"165035610923228403","age":21}],
"运维部":[{ "deptName":"运维部","name":"王五","id":"165035610923247204","age":22},
{ "deptName":"运维部","name":"赵六","id":"165035610923285576","age":22}]}直接分组好了展示我们想要的数据。那如果要使用JDK7 处理这种分组的香港云服务器情况,应该怎么处理呢?
是不是第一步要先考虑出循环出这个List里面都有哪些不同的部门,然后进行分组?
就这样,我想想都觉得头疼。要是能数据库操作,那直接数据库分组一下不就完事了,但是总是会有特殊情况需要我们去考虑的。所以,学会了绝对不吃亏。
阿粉今天说的这些简单快捷的小知识,你会用了么?