collection.stream()用法详解

stream()方法和collect()方法都是java8的新特性

List<String> widgetIds = widgets.stream().map(Widget::getWidgetId).collect(Collectors.toList());

解释下一这行代码:
widgets:一个实体类的集合,类型为List
Widget:实体类
getWidgetId:实体类中的get方法,为获取Widget的id
本来想要获得wiget的id集合,按照我的思路肯定是遍历widges,依次取得widgetIds,但是此行代码更加简洁,高效

stream()优点

无存储。stream不是一种数据结构,它只是某种数据源的一个视图,数据源可以是一个数组,Java容器或I/O channel等。
为函数式编程而生。对stream的任何修改都不会修改背后的数据源,比如对stream执行过滤操作并不会删除被过滤的元素,而是会产生一个不包含被过滤元素的新stream。
惰式执行。stream上的操作并不会立即执行,只有等到用户真正需要结果的时候才会执行。
可消费性。stream只能被“消费”一次,一旦遍历过就会失效,就像容器的迭代器那样,想要再次遍历必须重新生成。
stream().map()方法的使用示例:

List<String> list= Arrays.asList("a", "b", "c", "d");
List<String> collect =list.stream().map(String::toUpperCase).collect(Collectors.toList());
System.out.println(collect); //[A, B, C, D]
 
List<Integer> num = Arrays.asList(1,2,3,4,5);
List<Integer> collect1 = num.stream().map(n -> n * 2).collect(Collectors.toList());
System.out.println(collect1); //[2, 4, 6, 8, 10]

Lambda 之 Collection Stream

Collection.stream() 测试实体类
class Demo {
    private Long id;
    private String name;   
}

// 实例化并组成一个List

List<Demo> demos = Lists.newArrayList(new Demo(1L, "SF"), new Demo(2L, "AXE"));
1.map + collect用法
场景1:获取List列表的所有id No Lambda
public static List<Long> getIds(List<Demo> demos){
        List<Long> ids = Lists.newArrayList();
        for (Demo d : demos) {
            ids.add(d.getId());
        }
        return ids;
}

Lambda’s show

List<Long> ids = demos.stream().map(Demo::getId).collect(toList());

最后toList() 可以有更多的实现,比如

Set<Long> ids = demos.stream().map(Demo::getId).collect(toSet());

场景2:list变成map
有时候我们把list变成map,将多次List的O(n)遍历变成Map的O(1)查询,拿空间换时间
No lambda

public static Map<Long, Demo> getIds(List<Demo> demos){
        Map<Long, Demo> map = Maps.newHashMap;
        for (Demo d : demos) {
            map.put(d.getId, d);
        }
        return map;
}

Lambda‘s show

 Map<Long, Demo> map = demos.stream().collect(toMap(Demo::getId, o -> o));
2.filter
场景1:从List中找到name="SF"的Demo实例
No lambda
public static Demo getSpecifyDemo(String name, List<Demo> demos){
    Demo target = null;
    for (Demo demo : demos) {
        if (name.equals(demo.getName())) {
            target = demo;
        }
    }
    return target;
}

Lambda’s show–粗犷的老汉推车

String targetName = "SF";
Demo target = demos.stream().filter(d -> targetName.equals(d.getName())).findFirst().orElse(null);

这种写法非常简单,但是调用链太长,一个lambda能够绕地球好几圈,最好写成以下格式,防止步子迈得太大。
Lambda’s show–优雅传教士

Demo target = demos.stream()
            .filter(d -> targetName.equals.equals(d.getName()))
            .findFirst()
            .orElse(null);

find()的结果是Optional,Optional号称NPE终结者,于是对于find()的结果你可以随意使用终结者携带的任何武器,例如orElse(),ifPresent(),isPresent()…每个用起来都是那种哒哒哒冒蓝火的,更多姿势详见Optional的裸体源码。

3.match
match()是filter()的缩写版本,返回结果只有boolean类型,返回是否匹配。
场景1:当前list中某个元素是否符合某个条件 这个例子,给出另一个用法Demo::getId No lambda
List<String> condition = new ArrayList<>();
condition.add("SF");

public static boolean isExist(List<String> condition, List<Demo> demos){
    boolean flag = false;
    for (Demo demo : demos) {
        if (condition.contains(demo.getName())) {
            flag = true;
            break;
        }
    }
    return flag;
}

Lambda’s show 使用filter

boolean flag = demos.stream()
            .map(Demo::getName)
            .filter(condition::contains)
            .findAny()
            .isPresent();

Lambda’s show 直接使用match

boolean flag = demos.stream()
            .map(Demo::getName)
            .anyMatch(condition::contains);
  • 24
    点赞
  • 62
    收藏
    觉得还不错? 一键收藏
  • 3
    评论
StreamJava 8 引入的一个新特性,它可以用来处理集合或数组等数据源中的元素。Stream 提供了一种更加优雅、高效的方式来处理数据,代码可读性更强、更易维护。在 Stream 中,操作是延迟执行的,只有当需要结果的时候才会进行计算,这样就可以避免不必要的计算,提高程序的性能。 下面是 Stream 中常用的方法: 1. filter:过滤操作 该方法可以根据给定的条件过滤出符合条件的元素,返回一个新的 Stream。 ``` List<Integer> list = Arrays.asList(1, 2, 3, 4, 5); Stream<Integer> stream = list.stream().filter(i -> i % 2 == 0); // 过滤出偶数 ``` 2. map:映射操作 该方法可以将 Stream 中的每个元素按照给定的规则进行映射,返回一个新的 Stream。 ``` List<String> list = Arrays.asList("hello", "world", "java"); Stream<String> stream = list.stream().map(String::toUpperCase); // 将字符串转换为大写 ``` 3. flatMap:扁平化操作 该方法可以将一个包含多个 StreamStream 扁平化为一个单一的 Stream。 ``` List<List<Integer>> list = Arrays.asList(Arrays.asList(1, 2), Arrays.asList(3, 4), Arrays.asList(5, 6)); Stream<Integer> stream = list.stream().flatMap(Collection::stream); // 将多个 Stream 扁平化成一个 Stream ``` 4. distinct:去重操作 该方法可以去除 Stream 中重复的元素,返回一个新的 Stream。 ``` List<Integer> list = Arrays.asList(1, 2, 3, 2, 1); Stream<Integer> stream = list.stream().distinct(); // 去重 ``` 5. sorted:排序操作 该方法可以对 Stream 中的元素进行排序,返回一个新的 Stream。 ``` List<Integer> list = Arrays.asList(3, 1, 2, 5, 4); Stream<Integer> stream = list.stream().sorted(); // 排序 ``` 6. limit:截取操作 该方法可以截取 Stream 前面的 N 个元素,返回一个新的 Stream。 ``` List<Integer> list = Arrays.asList(1, 2, 3, 4, 5); Stream<Integer> stream = list.stream().limit(3); // 截取前面的三个元素 ``` 7. skip:跳过操作 该方法可以跳过 Stream 前面的 N 个元素,返回一个新的 Stream。 ``` List<Integer> list = Arrays.asList(1, 2, 3, 4, 5); Stream<Integer> stream = list.stream().skip(3); // 跳过前面的三个元素 ``` 8. forEach:遍历操作 该方法可以对 Stream 中的每个元素进行操作,没有返回值。 ``` List<Integer> list = Arrays.asList(1, 2, 3, 4, 5); list.stream().forEach(System.out::println); // 输出每个元素 ``` 9. count:计数操作 该方法可以返回 Stream 中元素的个数。 ``` List<Integer> list = Arrays.asList(1, 2, 3, 4, 5); long count = list.stream().count(); // 计算元素的个数 ``` 10. reduce:归约操作 该方法可以将 Stream 中的所有元素按照给定的规则进行归约,返回一个 Optional 类型的结果。 ``` List<Integer> list = Arrays.asList(1, 2, 3, 4, 5); Optional<Integer> result = list.stream().reduce((a, b) -> a + b); // 对元素求和 ``` 这些方法只是 Stream 中的一部分,Stream 还有很多其他的方法,可以根据具体需求进行选择和使用。
评论 3
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值