JDK8的几个方便快捷小知识

阿粉相信,个方JDK8 现在已经是便快非常普及的了,现在几乎百分之七十以上的知识公司都已经在使用了,虽然大部分的个方公司都换上了 JDK8 但是对于编码习惯来说,依然能够看到很多属于可以优化的便快代码,毕竟使用JDK8 进行编码的知识话,会让自己的个方代码看起来很优雅。阿粉今天就来看看 JDK7 和 JDK8 中的便快一些可以"优化"的代码。

JDK8 的知识 fro 循环

既然要说for循环,那么没有对比就没有伤害,个方我们来对比一下使用 JDK7 的便快 for 循环和使用 JDK8 的 for 循环。

获取List中所有人员的知识ID

获取值之前我们先给原始的 List 进行赋值:

private static ListgetList() {

User user = new User();

user.setId(UuidUtil.genLmnId());

user.setName("张三");

user.setAge(20);

user.setDeptName("开发部");

Listlist = new ArrayList();

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赋值

Listlist = getList();

//新的IdList

ListIds = new ArrayList<>();

for (User user: list) {

Ids.add(user.getId());

}

JDK8 获取Id数据:

Listjdk8Ids = list.stream().map(User::getId).collect(Collectors.toList());

System.out.println("JDK8的获取数据==="+JSON.toJSON(jdk8Ids));

这个时候就有的人会说,这算啥,便快就这点代码?知识

获取List数据中年龄大于等于21的站群服务器

传统做法,不用想,直接遍历,遍历之后,判断一下年龄是否是大于21,然后加入到新的对象中。这想法没错,那么我们来试试。

//给List赋值

Listlist = getList();

//新的list

ListnewList= new ArrayList<>();

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,代码来看看:

Listcollect = list.stream().filter(user -> user.getAge() >= 21).collect(Collectors.toList());

System.out.println("JDK8的获取数据==="+JSON.toJSON(collect));

我们看看数据:

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里面都有哪些不同的部门,然后进行分组?

就这样,我想想都觉得头疼。要是能数据库操作,那直接数据库分组一下不就完事了,但是总是会有特殊情况需要我们去考虑的。所以,学会了绝对不吃亏。

阿粉今天说的这些简单快捷的小知识,你会用了么?

人工智能
上一篇:域后缀首选.com,.net,然后是.cn。后缀选择不当,导致流量损失。域名是企业与互联网网址之间的链接,关键是企业在网络上存在的标志。因此,选择好域名是开展网上工作的首要重要条件。
下一篇:5. 四种状态过后,域名管理机构释放域名给公众注册。