Lambda方法引用&Stream流&单元测试&单例模式

这篇具有很好参考价值的文章主要介绍了Lambda方法引用&Stream流&单元测试&单例模式。希望对大家有所帮助。如果存在错误或未考虑完全的地方,请大家不吝赐教,您也可以点击"举报违法"按钮提交疑问。

总结

  • 回顾接口

    可存放:

    ​ 常量
    ​ 抽象方法
    ​ default方法
    ​ static方法

匿名内部类:接口和抽象类对象只使用一次,就可以使用匿名内部类

当使用匿名内部类创建一个函数式接口的时候,可以使用lambda来简化匿名内部类

public class ReviewLambdaDemo {
    public static void main(String[] args) {
        // 1、通过Runnable接口来创建线程对象
         new Thread(() -> System.out.println("2023要结束了")).start();

         // 2、在一个list集合里面放入5个数字,将按数字的降序排列
        ArrayList<Integer> list = new ArrayList<>();
        Collections.addAll(list,1,60,3,12,56);
        TreeSet<Integer> ts = new TreeSet<>((a,b) -> b - a);
        ts.addAll(list);
        System.out.println(ts);

        // 3、将一个指定文件夹里面所有ppt文件拿到
        File file = new File("e:/pp");
        File[] files = file.listFiles(f -> f.isFile() && f.getName().endsWith(".ppt"));
        // 遍历数组
        for (File f : files) {
            System.out.println(f);
        }

        // 4、随机产生10个不重复的随机偶数,遍历
        HashSet<Integer> set = new HashSet<>();
        while (set.size() < 10) {
            int num = (int)(Math.random() * 20 + 1);
            if(num % 2 != 0) continue;
            set.add(num);
        }
        set.forEach(a -> System.out.println(a));
    }

}

Lambda

  • 语法结构 简化使用匿名内部类创建对象的

  • 方法引用:简化特殊lambda

    构造方法引用:类名::new
    实例的方法的引用:对象名::方法名
    类方法的方法引用:类名::方法名

  • 讲解方法引用
    方法引用:对特殊的lambda简化的一种语法
    ()-> {lambda体}
    特殊的lambda:当lambda体只有1句代码,并且这句代码是在调用一个方法
    java中的方法:
    构造方法:new 构造方法()
    实例方法:对象名.方法名()
    类方法(静态方法):类名.方法名()

    构造方法的方法引用的语法:类名::方法名(简化lambda调用构造方法)

public class LambdaDemo1 {
    public static void main(String[] args) {
       // 创建IFacotryDog对象
        IFacotryDog ifd = (name,age) -> new Dog(name,age); // 创建函数接口对象
        Dog d = ifd.create("小可爱", 3);
        System.out.println(d);

        // 上面代码中lambda,可以使用构造方法的引用来简化
        // 创建IFacotryDog对象
        IFacotryDog ifd2 = Dog::new; // 类名:调用构造方法的类名::new
        Dog d2 = ifd2.create("老可爱", 3);
        System.out.println(d2);


    }
}
public class Dog {
    private String name;
    private Integer age;

    public Dog() {
    }

    public Dog(String name, Integer age) {
        this.name = name;
        this.age = age;
    }

    public String getName() {
        return name;
    }

    public void setName(String name) {
        this.name = name;
    }

    public Integer getAge() {
        return age;
    }

    public void setAge(Integer age) {
        this.age = age;
    }

    @Override
    public String toString() {
        return "Dog{" +
                "name='" + name + '\'' +
                ", age=" + age +
                '}';
    }
}
/**
 * 创建Dog对象的接口
 */
public interface IFacotryDog {
    Dog create(String name,Integer age);
}

类方法引用:类名(调用方法存放的类)::方法名(要调用的方法名)

public interface IChangeStringNumber {
    int change(String number);
}

/**
 * 讲解类方法引用:类名(调用方法存放的类)::方法名(要调用的方法名)
 */
public class LambdaDemo2 {
    public static void main(String[] args) {
        // 创建函数式接口IChangeStringNumber对象
        IChangeStringNumber  icsn = n -> Integer.parseInt(n);
        int num = icsn.change("123");
        System.out.println(num);
        
        // 上面代码中lambda是在调用一个类方法,使用类方法引用来简化:类名::方法
        
        IChangeStringNumber icsn2 = Integer::parseInt;
        icsn2.change("123");

    }
}

实例方法的引用:对象::实例方法名

/**
 * 设计一个函数式接口
 */
public interface IIsAvi {
    boolean isAvi(String filename);

}
/**
 * 讲解实例方法的引用
 */
public class LmbdaDemo3 {
    public static void main(String[] args) {

        // 创建IIsAvi对象
        IIsAvi avi = fn -> fn.endsWith(".avi"); // 创建函数式接口的对象
        boolean temp = avi.isAvi("蘋蘋在某酒店学习外语.png");
        System.out.println(temp);

        // lambda在调用一个实例方法,用实例方法引用来简化:对象::方法名

        String f = "xxxx.txt";
        IIsAvi avi2 = f::endsWith; // 实例方法的引用
        boolean avi1 = avi2.isAvi(f);
        System.out.println(avi1);

        // 遍历集合
        List<Integer> list = Arrays.asList(1, 2, 3, 4, 5, 6, 7);
//        PrintStream ps = System.out;
//        list.forEach(a -> ps.println(a));
        list.forEach(System.out::println);

    }
}

特殊:类名.方法名()

​ 引用类的实例方法是一种引用特定对象的实例方法。它通常用于将对象的方法作为Lambda表达式的一部分引用。

注意:仅限于对象的get()或)set()方法

stream.map(Person::getName); // 把对象转为对象的name

Stream流

IO流是操作文件流
Stream操作数组或者集合的流
注意:Stream只操作数据,不保存数据

  • 通过arrs数组创建Stream

    int[] arrs = {1,3,5,7,9};
    IntStream sm = Arrays.stream(arrs);

  • 通过集合对象创建Stream

    List list = Arrays.asList(1, 2, 3, 4, 56);
    Stream sm2 = list.stream();

/**
 * 讲解Stream流
 * IO流是操作文件流
 * Stream操作数组或者集合的流
 * 注意:Stream只操作数据,不保存数据
 *
 */
public class StreamDemo {
    public static void main(String[] args) {
        // 1、创建Stream
        // 1)、通过Arrays
        int[] arrs = {1,3,5,7,9};
        IntStream sm = Arrays.stream(arrs);// 通过arrs数组创建Stream
        // sm是Stream流对象,sm操作的数据源是arrs

        // 2)、通过集合对象
        List<Integer> list = Arrays.asList(1, 2, 3, 4, 56);
        Stream<Integer> sm2 = list.stream(); // 创建Stream对象
        
        // 3)、Stream里面的of方法
        Stream.of(1, 2, 3, 4, 5, 6);


    }
}
  • Stream流(重点)

    把数组和集合作为操作数据源

    • 创建Stream流对象
      1. 通过arrs数组创建Stream
      2. 通过集合对象创建Stream
  • 操作流的方法

    • Stream流的操作步骤:
      创建流对象(指定流操作数据源)
      操作流:过滤,切片,跳过,截取,去重,排序
      结束流:遍历、收集、统计

    操作流方法:

    filter(过滤的条件:函数式接口):将不满足条件的数据过滤掉 (Predicate:断言型的接口)

    limit(long 数字):截取流里面多个数据
    limit(3)
    .limit(3L) // 限制流里面显示的条数
    skip():跳过几条
    .skip(2L) // 跳过前两条
    .limit(4L) // 限制显示4条

    .distinct():去除重复

    .sorted():排序,进行排序数据必须实现Comparable
    .sorted() // 排序(升序)
    .sorted(Comparator):根据定制排序

    .map():切片(给你一种类型,变为另一种类型)

    结束流方法:注意:(结束流方法只能三选一)

    1. collect():收集
      collect(Collectors.toList()); // 将结果收集为一个集
    2. .count():统计个数
    3. forEach():遍历 (Consumer:消费型的接口)
public class StreamDemo2 {
    public static void main(String[] args) {
        // 1、创建流
//        IntStream stream = Arrays.stream(new int[]{1,8,6,8,10,12,14,16, 2, 3, 4, 5, 8,6,8,10,12,14,16});// 调用一个方法
//        List<Integer> list = Arrays.asList(1, 8, 6, 8, 10, 12, 14, 16, 2, 3, 4, 5, 8, 6, 8, 10, 12, 14, 16);
//        Stream<Integer> stream = list.stream();
//        // 2、操作流
//        stream
//                .filter(a -> a % 2 == 0) // Predicate:断言型的接口
//                filter(a -> a >= 4)
//                .distinct() // 去除重复数据
//                .sorted((o1,o2) -> o2 - o1) // 降序排列
//                .forEach(System.out::println); // Consumer:消费型的接口

            // 将字符串里面数字降序输出,去重
        String str = "12,34,67,5,90,23,4,67,8,9";
        String[] split = str.split(",");
        Stream<String> stream = Arrays.stream(split); // 创建流
        // 将字符串变成int
        long count = stream
                .map(Integer::parseInt) // Function,将a由String转换int
                .distinct() // 去重
                .sorted((o1, o2) -> o2 - o1)
                .count();// 统计流里面个数
        System.out.println(count);

    }
}

小结Stream流
Stream流的分类
1、串行流:单线程使用(使用最多)
2、并行流:多线程使用

1、创建流
Arrays.stream(数组)
集合对象.stream()
Stream.of(可变参数)

2、流操作的方法:
filter()
limit()
skip()
sorted()
distinct()
map()

forEach()
 collect()
 count();
    public static void main(String[] args) {
        // 创建一个串行流
        List<Integer> list = Arrays.asList(1, 2, 3, 4, 5, 6, 7, 8, 9);
//        Stream<Integer> stream = list.stream();// 创建的串行流
//        stream.forEach(System.out::println);

        // 并行流
        Stream<Integer> integerStream = list.parallelStream();
        integerStream.forEach(System.out::println);
    }
}
  • Stream的案例
public class StreamDemo4 {
    public static void main(String[] args) {
        // 1.有如下7个元素黄药师,冯蘅,郭靖,黄蓉,郭芙,郭襄,郭破虏,使用Stream将以郭字开头的元素存入新数组
//        String[] names = new String[]{"黄药师", "冯蘅", "郭靖", "黄蓉", "郭芙", "郭襄", "郭破虏"};
//        Stream<String> stream = Arrays.stream(names);
//        Object[] array = stream.filter(a -> a.startsWith("郭")).toArray();
//        Arrays.stream(array).forEach(System.out::println);

        // 2.已知ArrayList集合中有如下元素{陈玄风、梅超风、陆乘风、曲灵风、武眠风、冯默风、罗玉风},使用Stream
//        ArrayList<String> arrayList = new ArrayList<>();
//        arrayList.add("陈玄风");
//        arrayList.add("梅超风");
//        arrayList.add("陆乘风");
//        arrayList.add("曲灵风");
//        arrayList.add("武眠风");
//        arrayList.add("冯默风");
//        arrayList.add("罗玉风");
//        Stream<String> stream1 = arrayList.stream();
        //1、取出前2个元素并在控制台打印输出。
//        stream1.limit(2).forEach(System.out::println);
        //2、取出后2个元素并在控制台打印输出。
//        stream1.skip(arrayList.size() - 2).forEach(System.out::println);
//        Collections.reverse(arrayList);
//        arrayList.stream().limit(2).forEach(System.out::println);

          ArrayList<String> manArray = new ArrayList<>();
                manArray.add("刘德华");
                manArray.add("成龙");
                manArray.add("吴彦祖");
                manArray.add("周润发");
                manArray.add("周星驰");
                manArray.add("吴京");

                ArrayList<String> womanList = new ArrayList<>();
                womanList.add("林心如");
                womanList.add("孙俪");
                womanList.add("柳岩");
                womanList.add("林青霞");
                womanList.add("王祖贤");
                womanList.add("张曼玉");
        //1、筛选出前一个姓林的女演员
//        womanList.stream().filter(a -> a.startsWith("林")).limit(1).forEach(System.out::println);
        //2、男演员只要名字为3个字的前三人;
//        manArray.stream().filter(a -> a.length() == 3).limit(3).forEach(System.out::println);
        //    3、把上述过滤后的男演员姓名和女演员姓名合并到一起
        List<String> collect = manArray.stream().filter(a -> a.length() == 3).limit(3).collect(Collectors.toList());
        List<String> collect1 = Stream.concat(collect.stream(), womanList.stream()).collect(Collectors.toList());
        collect1.stream().forEach(System.out::println);
        //    4、把上一步操作后的元素作为构造方法的参数创建演员对象,遍


    }

}

单元测试

测试:检查代码有没有bug
黑盒测试:不看代码结构,只看结果
白盒测试:必须要看代码
灰盒测试:能看一部分代码
**注:**上面的测试是专业人员操作的

单元测试:测试自己写方法,程序员自己测
使用main方法来做,每一个只有一个main,测试很不方便
使用单元测试来代替main

  • 需要使用一个@Test的注解
  • 第一次使用需要导包
  • (重复的代码)需要使用一个@Before或者@After的注解
    • @Before:在每个测试方法执行之前要执行方法
    • @After:在每个测试方法执行之后要执行方法
  • 注意:单元测试的方法,不能有返回值,可以抛出Exception
public class TestCase {
    @Test // 单元测试的注解
    // 单元测试的方法,不能有返回值,可以抛出Exception
    public void testDemo1() throws Exception {
        System.out.println("这个单元测试1");
    }
    @Test
    public void testDemo2() throws Exception {

        System.out.println("这个单元测试2");
    }
    @Test
    public void testDemo3() throws Exception {

        System.out.println("这个单元测试3");
    }
    // 在测试方法代码冗余(重复的代码)
    @Before // 在每个测试方法执行之前要执行方法
    public void before() throws Exception {
        System.out.println("hello");
    }

    @After
    public void after() throws  Exception {
        System.out.println("用来释放锁,关闭流");
    }


}

单例模式

一个类就是只有一个对象,那么就是单例
将一个类设计成单例的方式就是单例模式

怎样将一个类设计为单例
1、私有构造方法
2、在当前类创建对象
3、在该类设计一个类方法,返回这个对象文章来源地址https://www.toymoban.com/news/detail-775088.html

package cn.itsource.singleton;

/**
 * 将Dog设计为单例:饿汉模式
 */
public class Dog {
    // 2、创建对象
    private static Dog d = new Dog(); // 不管这个对象用不用,在内存中存在
    // 省略属性
    // 1、私有化构造方法
    private Dog() {}

    // 3、设计一个类方法,返回创建的对象
    public static Dog getInstance() {
        return d;
    }
}
public class SingletonDemo {
    public static void main(String[] args) {
        Dog d1 = Dog.getInstance();
        System.out.println(d1);
        Dog d2 = Dog.getInstance();
        System.out.println(d2);
        Dog d3 = Dog.getInstance();
        System.out.println(d3);
    }
}

到了这里,关于Lambda方法引用&Stream流&单元测试&单例模式的文章就介绍完了。如果您还想了解更多内容,请在右上角搜索TOY模板网以前的文章或继续浏览下面的相关文章,希望大家以后多多支持TOY模板网!

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处: 如若内容造成侵权/违法违规/事实不符,请点击违法举报进行投诉反馈,一经查实,立即删除!

领支付宝红包 赞助服务器费用

相关文章

  • Java Lambda Stream

    条件:lambada表达式的主体仅包含一个表达式,且lambada表达式只调用一个已经存在的方法;被引用的方法的参数列表与lambada表达式的输入输出一致 以下是Java 8中方法引用的一些语法: 静态方法引用(static method)语法: classname::methodname 例如: Person::getAge 对象的实例方法引用

    2024年02月02日
    浏览(28)
  • Java实现单例模式的几种方法

    单例模式作为23中设计模式中最基础的设计模式,一般实现方式为 ①私有化构造方法 ②提供一个获取对象的静态方法 除此之外,实现单例模式的方法还有很多种,这篇文章主要介绍实现单例模式的几种方法。 目录 一、懒汉式单例 二、懒汉式单例优化(双重检测锁) 三、饿

    2024年02月12日
    浏览(41)
  • Java重修第九天—Lambda 表达式和Stream

    通过学习本篇文章可以掌握如下知识 Lambda 表达式 Stream Lambda表达式是JDK 8开始新增的一种语法形式;作用: 用于简化 函数式接口 匿名内部类的代码写法 函数式接口:首先是接口,其次是只有一个抽象方法。 代码实现 java中Comparator就是一个函数式接口,可以使用lambda进行简

    2024年01月22日
    浏览(46)
  • JAVA8-lambda表达式8:在设计模式-模板方法中的应用

    JAVA8-lambda表达式1:什么是lambda表达式 JAVA8-lambda表达式2:常用的集合类api JAVA8-lambda表达式3:并行流,提升效率的利器? JAVA8-lambda表达式4:Optional用法 java8-lambda表达式5:toMap引发的线上故障 JAVA8-lambda表达式6:重构和定制收集器 JAVA8-lambda表达式7:重要的函数接口 最近在公司

    2024年02月14日
    浏览(52)
  • Lambda表达式与“::“方法引用 & 判空包装类Optional

    函数式接口(Functional Interface)就是有且仅有一个抽象方法,但是可以有多个非抽象方法的接口。 函数式接口可以被隐式转换为Lambda表达式。 方法引用主要是对Lambda表达式的一种优化! 方法引用的使用前提是对象和方法都是已经存在的! 方法引用提供了一种引用而不执行方

    2024年02月06日
    浏览(39)
  • Java单元测试之Mock指定方法

    单元测试时,假如你遇到某个内部方法无法正常调用;我们可以使用mock工具去解决,方法如下:

    2024年02月13日
    浏览(44)
  • java 单元测试创建到测试(直接连接数据库方法)

    一.JUnit5常用注解 @Before注解用于在测试方法执行之前执行一次,可以用来设置测试环境、准备数据等。 @After注解用于在测试方法执行之后执行一次,可以用来清理测试环境、处理异常等。 @Test 表示方法是测试方法。他的职责非常单一不能生命任何属性,拓展的测试将会有

    2024年02月06日
    浏览(47)
  • Java中的JUnit单元测试方法的使用

    选中当前工程 - 右键选择:build path - add libraries - JUnit 4 - 下一步 创建Java类,进行单元测试。 此时的Java类要求:① 此类是public的 ②此类提供公共的无参的构造器 此类中声明单元测试方法。 此时的单元测试方法:方法的权限是public,没有返回值,没有形参。 此单元测试方法上

    2024年02月14日
    浏览(41)
  • Java对私有方法进行单元测试及示例

    在Java中,我们不能直接对私有方法进行单元测试。因为单元测试的目的是测试公共接口,而私有方法是内部实现的一部分。然而,如果有必要测试私有方法,可以使用反射来访问和调用私有方法。 以下是一个使用反射测试私有方法的示例: 在上述示例中,我们创建了一个

    2024年02月06日
    浏览(43)
  • Optional常用方法实例, 源码挺简单的,重要的是option 与 stream 以及lambda 的连贯使用

    ​empty(): ​of() // 非null 就继续执行 否则抛异常 ​ ofNullable () ​get() //非null就get 否则异常 ​//lambada // 根据是否为NULL进行操作 ​// filter进行以上对下进行输入 如果opt是一集合的话 , 无法进行筛选 , 只能使用集合本身进行filter 取到map orElseThrow() //是空就抛出自定义异常

    2024年02月05日
    浏览(36)

觉得文章有用就打赏一下文章作者

支付宝扫一扫打赏

博客赞助

微信扫一扫打赏

请作者喝杯咖啡吧~博客赞助

支付宝扫一扫领取红包,优惠每天领

二维码1

领取红包

二维码2

领红包