JAVA803_Stream流的生产方式forEachfiltermaplimitskipconcatdistinctsortedcollect
Posted 所得皆惊喜
tags:
篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了JAVA803_Stream流的生产方式forEachfiltermaplimitskipconcatdistinctsortedcollect相关的知识,希望对你有一定的参考价值。
文章目录
①. Stream 流的常见生产方式
-
①. Collection体系的集合可以使用默认方法stream()生成流
default Stream<E> stream()
-
②. Map体系的集合间接的生成流
-
③. 数组可以通过Stream接口的静态方法of(T… values)生成流
public class StreamDemo {
public static void main(String[] args) {
//Collection体系的集合可以使用默认方法stream()生成流
List<String> list = new ArrayList<String>();
Stream<String> listStream = list.stream();
Set<String> set = new HashSet<String>();
Stream<String> setStream = set.stream();
//Map体系的集合间接的生成流
Map<String,Integer> map = new HashMap<String, Integer>();
Stream<String> keyStream = map.keySet().stream();
Stream<Integer> valueStream = map.values().stream();
Stream<Map.Entry<String, Integer>> entryStream = map.entrySet().stream();
//数组可以通过Stream接口的静态方法of(T... values)生成流
String[] strArray = {"hello","world","java"};
Stream<String> strArrayStream = Stream.of(strArray);
Stream<String> strArrayStream2 = Stream.of("hello", "world", "java");
Stream<Integer> intStream = Stream.of(10, 20, 30);
}
}
②. forEach Consumer
-
①. 然方法名字叫forEach ,但是与for循环中的“for-each”昵称不同
void forEach(Consumer<? super T> action); -
②. java.util.function.Consumer
<T>
接口是一个消费型接口。Consumer接口中包含抽象方法void accept(T t),意为消费一个指定泛型的数据。
Stream<String> st1 = Stream.of("张三","李四","王二","麻子");
st1.forEach(System.out::println);
// 等同于如下代码
// st1.forEach(s -> System.out.println(s));
③. filter Predicate
-
①.
Stream<T> filter(Predicate predicate):
用于对流中的数据进行过滤 -
②. Predicate接口中的方法
boolean test(T t):
对给定的参数进行判断,返回一个布尔值 -
③. java.util.stream.Predicate函数式接口唯一的抽象方法为boolean test(T t);,该方法将会产生一个boolean值结果,代表指定的条件是否满足。如果结果为true,那么Stream流的filter方法将会留用元素;如果结果为false,那么filter方法将会舍弃元素
public class StreamDemo01 {
public static void main(String[] args) {
//创建一个集合,存储多个字符串元素
ArrayList<String> list = new ArrayList<String>();
list.add("林青霞");
list.add("张曼玉");
list.add("王祖贤");
list.add("柳岩");
list.add("张敏");
list.add("张无忌");
//需求1:把list集合中以张开头的元素在控制台输出
// list.stream().filter((String s) -> {
// return s.startsWith("张");
// }).forEach(System.out::println);
list.stream().filter(s -> s.startsWith("张")).forEach(System.out::println);
System.out.println("--------");
//需求2:把list集合中长度为3的元素在控制台输出
list.stream().filter(s -> s.length() == 3).forEach(System.out::println);
System.out.println("--------");
//需求3:把list集合中以张开头的,长度为3的元素在控制台输出
list.stream().filter(s -> s.startsWith("张")).filter(s -> s.length() == 3).forEach(System.out::println);
}
}
④. map Function
-
①. 如果需要将流中的元素映射到另一个流中,可以使用map方法,方法签名:
<R>
Stream<R>
map(Function<? super T, ? extends R> mapper); -
②. 该接口需要一个Function函数式接口,可以将当前流中的T类型数据转换为另一种R类型的流
此前我们已经学习过 java.util.stream.Function 函数式接口,其中唯一的抽象方法为:R apply(T t);,这可以将一种T类型转换成为R类型,而这种转换的动作,就称为“映射”
// map 方法的参数通过方法引用,将字符串类型转换成为了int类型(并自动装箱为 Integer 类对象)
Stream.of("1","2","3","4","5","6")
.map(Integer::parseInt)
.forEach(s -> System.out.println(s*10));
⑤. limit 和 skip
-
①.
Stream<T> limit(long maxSize)
:返回此流中的元素组成的流,截取前指定参数个数的数据 -
②.
Stream<T> skip(long n):
跳过指定参数个数的数据,返回由该流的剩余元素组成的流
public class StreamDemo02 {
public static void main(String[] args) {
//创建一个集合,存储多个字符串元素
ArrayList<String> list = new ArrayList<String>();
list.add("林青霞");
list.add("张曼玉");
list.add("王祖贤");
list.add("柳岩");
list.add("张敏");
list.add("张无忌");
//需求1:取前3个数据在控制台输出
list.stream().limit(3).forEach(System.out::println);
System.out.println("--------");
//需求2:跳过3个元素,把剩下的元素在控制台输出
list.stream().skip(3).forEach(System.out::println);
System.out.println("--------");
//需求3:跳过2个元素,把剩下的元素中前2个在控制台输出
list.stream().skip(2).limit(2).forEach(System.out::println);
}
}
⑥. concat 、distinct
-
①.
static <T> Stream<T> concat(Stream a, Stream b):
合并a和b两个流为一个流 -
②.
Stream<T> distinct():
返回由该流的不同元素(根据Object.equals(Object) )组成的流
public class StreamDemo03 {
public static void main(String[] args) {
//创建一个集合,存储多个字符串元素
ArrayList<String> list = new ArrayList<String>();
list.add("林青霞");
list.add("张曼玉");
list.add("王祖贤");
list.add("柳岩");
list.add("张敏");
list.add("张无忌");
//需求1:取前4个数据组成一个流
Stream<String> s1 = list.stream().limit(4);
//需求2:跳过2个数据组成一个流
Stream<String> s2 = list.stream().skip(2);
//需求3:合并需求1和需求2得到的流,并把结果在控制台输出
// Stream.concat(s1,s2).forEach(System.out::println);
//需求4:合并需求1和需求2得到的流,并把结果在控制台输出,要求字符串元素不能重复
Stream.concat(s1,s2).distinct().forEach(System.out::println);
}
}
⑦. sorted 排序
-
①.
Stream<T> sorted():
返回由此流的元素组成的流,根据自然顺序排序 -
②.
Stream<T> sorted(Comparator comparator):
返回由该流的元素组成的流,根据提供的Comparator进行排序Comparator接口中的方法 int compare(T o1, T o2)
public class StreamDemo04 {
public static void main(String[] args) {
//创建一个集合,存储多个字符串元素
ArrayList<String> list = new ArrayList<String>();
list.add("linqingxia");
list.add("zhangmanyu");
list.add("wangzuxian");
list.add("liuyan");
list.add("zhangmin");
list.add("zhangwuji");
//需求1:按照字母顺序把数据在控制台输出 sorted()是正序
// list.stream().sorted().forEach(System.out::println);
//需求2:按照字符串长度把数据在控制台输出
// list.stream().sorted((s1, s2) -> s1.length() - s2.length()).forEach(System.out::println);
list.stream().sorted((s1,s2) -> {
int num = s1.length()-s2.length();
int num2 = num==0?s1.compareTo(s2):num;
return num2;
}).forEach(System.out::println);
}
}
⑧. collect
-
①. toList:将流中的元素放置到一个列表集合中去。这个列表默认为ArrayList
-
②. toSet:将流中的元素放置到一个无序集set中去。默认为HashSet。
-
③. joining:joining的目的是将流中的元素全部以字符序列的方式连接到一起,可以指定连接符,甚至是结果的前后缀
public class CollectorsTest {
public static void toListTest(List<String> list) {
List<String> ll = list.stream().collect(Collectors.toList());
}
public static void main(String[] args) {
List<String> list = Arrays.asList("123","456","789","1101","212121121","asdaa","3e3e3e","2321eew");
toListTest(list);
}
}
public class CollectorsTest {
public static void toSetTest(List<String> list) {
Set<String> ss = list.stream().collect(Collectors.toSet());
}
public static void main(String[] args) {
List<String> list = Arrays.asList("123","456","789","1101","212121121","asdaa","3e3e3e","2321eew");
toSetTest(list);
}
}
public class CollectorsTest {
public static void joiningTest(List<String> list){
// 无参方法
String s = list.stream().collect(Collectors.joining());
System.out.println(s);
// 指定连接符
String ss = list.stream().collect(Collectors.joining("-"));
System.out.println(ss);
// 指定连接符和前后缀
String sss = list.stream().collect(Collectors.joining("-","S","E"));
System.out.println(sss);
}
public static void main(String[] args) {
List<String> list = Arrays.asList("123","456","789","1101","212121121","asdaa","3e3e3e","2321eew");
joiningTest(list);
}
}
/*
1234567891101212121121asdaa3e3e3e2321eew
123-456-789-1101-212121121-asdaa-3e3e3e-2321eew
S123-456-789-1101-212121121-asdaa-3e3e3e-2321eewE
*/
⑨. 题目实战
/**
* @Description: 题目:请按照给出数据,找出同时满足以下条件的用户,也即以下条件全部满足
* 偶数ID且年龄大于24且用户名转为大写且用户名字母倒排序
只输出一个用户名字
*/
public class StreamDemo {
public static void main(String[] args) {
User u1 = new User(11, "a", 23);
User u2 = new User(12, "b", 24);
User u3 = new User(13, "c", 22);
User u4 = new User(14, "d", 28);
User u5 = new User(16, "e", 26);
List<User> list = Arrays.asList(u1, u2, u3, u4, u5);
list.stream()
.filter(s->s.getId()%2==0)
.filter(s->s.getAge()>24)
.map(s->s.getUserName().toUpperCase())
.sorted((s1,s2)->s2.compareTo(s1))
.limit(1)
.forEach(System.out::print);
}
}
以上是关于JAVA803_Stream流的生产方式forEachfiltermaplimitskipconcatdistinctsortedcollect的主要内容,如果未能解决你的问题,请参考以下文章