Java8之Stream流代替For循环操作

网友投稿 253 2023-03-25

Java8之Stream流代替For循环操作

Stream流代替For循环进行输出可以使代码更简洁。

需求:根据姓名获取员工信息

1.建立实体类:Emp

public class Emp {

private String id;

private String name;

public Emp(String id, String name) {

this.id=id;

this.name=name;

}

public String getId() {

return id;

}

public void setId(String id) {

this.id = id;

}

public String getName() {

return name;

}

public void setName(String name) {

this.name = name;

}

@Override

public String toString() {

return "Emp信息: [id=" + id + ", name=" + name + "]";

}

2.测试类:

(1.) 原始For写法:

List emps = new ArrayList<>();

emps.add(new Emp("00101","张三"));

emps.add(new Emp("00102","张四"));

emps.add(new Emp("00103","张五"));

emps.add(new Emp("00104","张六"));

emps.add(new Emp("00105","张七"));

for (Emp emp : emps) {

if (emp.getName().equals("张三")) {

System.out.println(emp);

return;

}

}

(2.) Stream流:

List emps = new ArrayList<>();

emps.add(new Emp("00101","张三"));

emps.add(new Emp("00102","张四"));

emps.add(new Emp("00103","张五"));

emps.add(new Emp("00104","张六"));

emps.add(new Emp("00105","张七"));

//filter()定义方法,toList()输出为list

List emp=emps.stream().filter(e -> "张三".equals(e.getName())).collect(Collectors.toList());

emp.forEach(System.out::println);

输出结果为:

补充知识:java中for、foreach、stream性能比较

我们在开发中循环遍历一个数组经常会用到,jdk8推出了一些新特性,对循环做了比较,通过代码亲测,记录一下!

1、for循环

public static void main(String[] args) {

Long startTime = System.currentTimeMillis();

formMethod();

Long endTime = System.currentTimeMillis();

System.out.println("result:" + (endTime - startTime));

}

public static void formMethod(){

for (int i = 0; i < 10000; i++) {

System.out.println("start::::::::::::");

}

}

2、foreach循环(for循环的增强版)

public static void main(String[] args) {

List list = new ArrayList();

for (int i = 0; i < 10000; i++) {

list.add(i);

}

Long startTime = System.currentTimeMillis();

foreachMethod(list);

Long endTime = System.currentTimeMillis();

System.out.println("result:" + (endTime - startTime));

}

/**

* foreach

* @param list

*/

public static void foreachMethod(List list){

list.forEach(i ->{

System.out.println("++++++++++++");

});

}

结论:通过代码测试发现在1万以xUDpuldF内的数据,for循环比foreach效率要高一些;但是10万以内数据的时候,foreach效率更高一些!

foreach [10万数据时间 1112 1165 1203 1115] [1万数据 235 146 176 164 175]

for循环 [10万数据时间 1330 1437 1347] [1万数据 110 109 141]

3、stream api

(1)、串行处理,即同步处理

public static void main(String[] args) {

List list = new ArrayList();

for (int i = 0; i < 10000; i++) {

list.add(i);

}

Long startTime = System.currentTimeMillis();

streamMethod(list);

Long endTime = System.currentTimeMillis();

System.out.println("result:" + (endTime - startTime));

}

/**

* stream 串行处理

* @param list

*/

public static void streamMethod(List list){

list.stream().forEach(i ->{

System.out.println("========");

});

}

结论:1万以内的数据,for循环的性能要高于foreach和stream;10万以内的数据明显可以看出stream效率最高,其次foreach,最后是for。

[10万数据时间 854 892 789 844][1万数据 172 156 219 172 171]

(2)并行处理,即stream api提供了异步处理机制

public static void main(String[] args) {

List list = new ArrayList();

for (int i = 0; i < 10000; i++) {

list.add(i);

}

Long startTime = System.currentTimeMillis();

parallelStreamMethod(list);

Long endTime = System.currentTimeMillis();

System.out.println("result:" + (endTime - startTime));

}

/**

* stream 并行处理

* @param list

*/

public static void parallelStreamMethod(List list){

list.parallelStream().forEach(i ->{

System.out.println("========");

});

}

结论:1万以内的数据,for循环的性能要高于foreach和stream;10万以内的数据明显可以看出stream效率最高,其次foreach,最后是for。

[10万数据时间 893 844 914 972][1万数据 219 203 234 188 ]

最终总结:如果数据在1万以内的话,for循环效率高于foreach和stream;如果数据量在10万的时候,stream效率最高,其次是foreach,最后是for。另外需要注意的是如果数据达到100万的话,parallelStream异步并行处理效率最高,高于foreach和for。

版权声明:本文内容由网络用户投稿,版权归原作者所有,本站不拥有其著作权,亦不承担相应法律责任。如果您发现本站中有涉嫌抄袭或描述失实的内容,请联系我们jiasou666@gmail.com 处理,核实后本网站将在24小时内删除侵权内容。

上一篇:动物识别 (动物识别扫一扫)(4分钟之前已更新)
下一篇:充值接口 (话费充值接口)(52秒之前已更新)
相关文章

 发表评论

暂时没有评论,来抢沙发吧~