一、简介
常用的4种stream()用法。
(1) list.stream().map().collect() 方法,可以获取list中javabean的某个字段,转成一个新的list。
(2) list.stream().filter().map().collect() 方法,可以对list中的javabean进行筛选,保留符合条件的 javabean,然后将javabean中的某个字段,转成一个新的list。
(3) list.stream().collect() 方法,可以把list转为map,可以指定list的中的javabean的某个字段或javabean本身为map的key或value。(或者根据情况自定义map的key与value)
(4) list.stream().filter().collect() 方法,可以先筛选出list中符合条件的javabean,然后把list转为map,可以指定list的中的javabean的某个字段或javabean本身为map的key或value。(或者根据情况自定义map的key与value)
二、代码样例
import java.util.arraylist;
import java.util.list;
import java.util.map;
import java.util.set;
import java.util.stream.collectors;
public class test {
public static void main(string[] args) {
bean bean1 = new bean(1, "a", "za");
bean bean2 = new bean(2, "b", "zb");
bean bean3 = new bean(3, "c", "zc");
arraylist<bean> list1 = new arraylist();
list1.add(bean1);
list1.add(bean2);
list1.add(bean3);
//获取list1中的所有bean对象的id,放入另一个list数组
//注意,这个.map()方法返回的还是流对象,而不是返回map的意思
//.stream().map().collect()
list<long> ids = list1.stream().map(bean -> bean.getid()).collect(collectors.tolist());
system.out.println("ids=========" + ids);
//使用filter方法,筛选list1中的所有bean对象,留下id属于ids中的bean对象,并把它们的name字段转成一个list
//删除一个,便于看出差别来
ids.remove(0);
//.stream().filter().map().collect()
list<string> names = list1.stream().filter(bean -> ids.contains(bean.getid())).map(bean::getname).collect(collectors.tolist());
//list<string> names = list1.stream().filter(bean -> ids.contains(bean.getid())).map(bean -> bean.getname()).collect(collectors.tolist());
system.out.println("names====" + names);
//把list1中的所有bean对象转成map,其中,id是map的key,bean对象本身是map的value
//.stream().collect()
map<long, bean> maps = list1.stream().collect(java.util.stream.collectors.tomap(bean::getid, e -> e));
//map<long, string> maps = list1.stream().collect(collectors.tomap(bean::getid, e -> e.getname()));
system.out.println("maps====" + maps);
set<long> longs = maps.keyset();
system.out.println("longs====" + longs);
for (long l : longs) {
system.out.print(l + " " + maps.get(l).getname() + " | ");
}
system.out.println();
//按条件过滤后生成map,与上方的filter类似,只保留ids中有的id的bean对象
//.stream().filter().collect()
map<long, bean> maps2 = list1.stream().filter(bean -> ids.contains(bean.getid())).collect(java.util.stream.collectors.tomap(bean::getid, e -> e));
system.out.println(maps2);
set<long> longs2 = maps2.keyset();
for (long l : longs2) {
system.out.print(l + " " + maps2.get(l).getname() + " | ");
}
system.out.println();
}
static class bean {
private long id;
private string name;
private string address;
public bean(long id, string name, string address) {
this.id = id;
this.name = name;
this.address = address;
}
public long getid() {
return id;
}
public void setid(long id) {
this.id = id;
}
public string getname() {
return name;
}
public void setname(string name) {
this.name = name;
}
public string getaddress() {
return address;
}
public void setaddress(string address) {
this.address = address;
}
}
}总结
到此这篇关于java中list常用的4种stream()方法的文章就介绍到这了,更多相关java list的stream()方法内容请搜索代码网以前的文章或继续浏览下面的相关文章希望大家以后多多支持代码网!
发表评论