Lambda、函数式接口、Stream流、序列化

一、Lambda表达式

函数编程思想
(1).不使用Lambda:需要定义类、创建对象;
(2).使用Lambda:不需要定义类,不需要创建对象。
Lambda相对于面向对象编程的优势:写法简单,可读性强。
缺省规则
1).形参相关:形参的数据类型都可以省略。
2).形参相关:如果形参只有一个,可以同时省略:数据类型、一对小括号。
注:如果省略小括号,必须同时省略数据类型
如果省略数据类型,可以不省略小括号。
3).方法体相关:如果方法体中只有一句话,可以同时省略:一对大括号、语句后的分号、最后的return关键字。
要省就全省,要用就全用

二、函数式接口

概述::有且只有一个“自定义”的抽象方法(可以包含同Object类中声明相同的抽象方法),这种接口叫:函数式接口。
函数式接口:Consumer接口
demo

	class Zi implements Consumer<String>{
    @Override
    public void accept(String s) {
        //转换为大写输出
        System.out.println(s.toUpperCase());
    }
}
public class Demo {
    public static void main(String[] args) {
        //1.子类形式
        Zi z = new Zi();
        fun(z);
        //2.匿名内部类形式
        fun(new Consumer<String>() {
            @Override
            public void accept(String s) {
                //转换为大写输出
                System.out.println(s.toUpperCase());
            }
        });
        
        //3.Lambda的形式
        fun(s -> System.out.println(s.toUpperCase()));
    }

    public static void fun(Consumer<String> con){
        con.accept("Hello");

    }
}

函数式接口:Predicate接口(判断接口)
demo

	class Zi implements Predicate<Integer> {
    @Override
    public boolean test(Integer integer) {
        return integer > 10;
    }
}
public class Demo {
    public static void main(String[] args) {
        //1.子类的形式
        fun(new Zi());
        //2.匿名内部类的形式
        fun(new Predicate<Integer>() {
            @Override
            public boolean test(Integer integer) {
                return integer > 10;
            }
        });
        //3.Lambda表达式:
        fun(n -> n > 10);
        
    }
    
    public static void fun(Predicate<Integer> p){
        boolean b = p.test(20);
        System.out.println("判断结果:" + b);
    }
}

三、stream流

常用方法:
在这里插入图片描述
获取方式
1).通过Collection集合获取流:Collection接口的:默认方法:stream()获取流:
2).通过Map集合获取流:
3).通过数组(引用类型)获取流:
4).通过数组(基本类型)获取流:
5).通过零散数据获取流:
demo

	public static void main(String[] args) {
    //1).通过Collection集合获取流:Collection接口的:默认方法:stream()获取流:
    List<String> strList = new ArrayList<>();
    Stream<String> stream1 = strList.stream();

    Set<String> strSet = new HashSet<>();
    Stream<String> stream2 = strSet.stream();


    //2).通过Map集合获取流:【Map集合不能直接获取流】
    Map<Integer, String> map = new HashMap<>();
    //2-1:获取键的流
    Stream<Integer> keyStream = map.keySet().stream();
    //2-2:获取值的流
    Stream<String> valueStream = map.values().stream();
    //2-3:获取Entry的流
    Stream<Map.Entry<Integer, String>> entryStream = map.entrySet().stream();


    //3).通过数组(引用类型)获取流:
    Integer[] integerArray = {10, 20, 30};
    Stream<Integer> integerStream1 = Arrays.stream(integerArray);//方式一
    Stream<Integer> integerStream2 = Stream.of(integerArray);//方式二,注意:只能接收引用类型数组

    //4).通过数组(基本类型)获取流:
    int[] intArray = {1, 2, 3, 4};
    IntStream intStream1 = Arrays.stream(intArray);//方式一:
    IntStream intStream2 = IntStream.of(intArray);//方式二:


    //5).通过零散数据获取流:
    Stream<Integer> integerStream = Stream.of(10, 20, 30, 40, 50, 60, 70, 80);

}

综合案例

	public static void main(String[] args) {
    List<String> one = new ArrayList<>();
    one.add("迪丽热巴");
    one.add("宋远桥");
    one.add("苏星河");
    one.add("老子");
    one.add("庄子");
    one.add("孙子");
    one.add("洪七公");

    List<String> two = new ArrayList<>();
    two.add("古力娜扎");
    two.add("张无忌");
    two.add("张三丰");
    two.add("赵丽颖");
    two.add("张二狗");
    two.add("张天爱");
    two.add("张三");

    /*
        1. 第一个队伍只要名字为3个字的成员姓名;
        2. 第一个队伍筛选之后只要前3个人;

        3. 第二个队伍只要姓张的成员姓名;
        4. 第二个队伍筛选之后不要前2个人;

        5. 将两个队伍合并为一个队伍;
        6. 打印整个队伍的姓名信息。
     */
    Stream.concat(one.stream().filter(s -> s.length() == 3).limit(3),
    two.stream().filter(s -> s.startsWith("张")).skip(2))
            .forEach(s -> System.out.println(s));
}

将Stream中的数据提取到集合或数组中

	public static void main(String[] args) {
    List<String> one = new ArrayList<>();
    one.add("迪丽热巴");
    one.add("宋远桥");
    one.add("苏星河");
    one.add("老子");
    one.add("庄子");
    one.add("孙子");
    one.add("洪七公");

    //筛选出名字为三个字的学员,并存储到新集合
    List<String> collect = one.stream().filter(s -> s.length() == 3)
                                .collect(Collectors.toList());

    //转换为数组
    Object[] objArray = one.stream().filter(s -> s.length() == 3)
                            .toArray();
}

四、序列化

“序列化”:将一个“内存中的对象”的“名字” ,以及“属性的值”一起存储到一个“文件”中,这个过程叫:序列化。
“反序列化”:将之前“序列化”的对象,再次的“加载到内存,并创建对象”,这个过程叫:反序列化。

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
Stream 是 Java 8 提供的一个用于处理集合数据的函数编程 API。Stream API 可以让我们以一种声明的方处理集合数据,避免了传统的迭代方,使代码更加简洁和易读。 而(Stream)是一个来自数据源的元素队列并支持聚合操作。元素是特定类型的对象,形成一个队列。操作可以执行顺序或并行。Java 中的 Stream API 可以使得我们可以使用一种类似于 SQL 语句在集合中执行操作。 Stream API 的主要特点如下: - Stream 不存储数据,它们只是在源的基础上提供了一种视图。 - Stream 操作是延迟执行的,只有当终止操作调用时才会执行。 - Stream 可以操作集合、数组等数据源。 - Stream 提供了丰富的中间操作和终止操作,可以实现过滤、映射、排序、聚合等功能。 函数接口(Functional Interface)是 Java 8 中引入的一个概念,它是只包含一个抽象方法的接口Stream API 使用了函数接口作为其操作的参数,例如 filter、map、reduce 等方法都接受函数接口作为参数,以便进行相应的操作。 在 Stream API 中,常用的函数接口有 Predicate、Function、Consumer、Supplier 等,它们可以通过 Lambda 表达或方法引用来创建,并可以与操作相结合使用,实现各种数据处理操作。 希望这个回答能够解决你对 Stream 函数接口的疑问。如果还有其他问题,请随时提问!

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值