2024年Java SE 学习记录——进阶版12(2),最详细的解释小白也能听懂

img
img

网上学习资料一大堆,但如果学到的知识不成体系,遇到问题时只是浅尝辄止,不再深入研究,那么很难做到真正的技术提升。

需要这份系统化资料的朋友,可以戳这里获取

一个人可以走的很快,但一群人才能走的更远!不论你是正从事IT行业的老鸟或是对IT行业感兴趣的新人,都欢迎加入我们的的圈子(技术交流、学习资源、职场吐槽、大厂内推、面试辅导),让我们一起学习成长!

package day_12FunctionInterface.demo01FunctionInterface;

public class MyFunctionInterfaceImpl implements MyFunctionInterface{
@Override
public void method() {

}

}


  

###### 23-03 函数式接口的使用



package day_12FunctionInterface.demo01FunctionInterface;

/*
函数式接口的使用:一般可以作为方法的参数和返回值类型
*/
public class Demo {
// 定义一个方法,参数使用函数式接口MyFunctionInterface
public static void show(MyFunctionInterface mfi) {
mfi.method();
}

public static void main(String[] args) {
    // 调用show方法
    show(new MyFunctionInterfaceImpl());

    // 传递接口的匿名内部类
    show(new MyFunctionInterface() {
        @Override
        public void method() {
            System.out.println("使用匿名内部类重写接口的抽象方法");
        }
    });

    // 传递Lambda表达式
    show(()-> System.out.println("传递Lambda表达式"));
}

}


  

#### 第二章 函数式编程


##### 2.1 Lambda的延迟执行


性能浪费的日志案例  
 体验Lambda的更优写法  
 证明Lambda的延迟


###### 23-04 性能浪费的日志案例



package day_12FunctionInterface.demo02Lambda;

/*
日志案例

发现以下代码存在性能浪费
先拼接好字符串再调用showLog方法,如果日志的等级不是1,则不会输出拼接后的字符串,存在性能的浪费
*/
public class Demo01Logger {
// 定义一个根据日志的级别写是日志信息的方法
public static void showLog(int level, String message) {
// 对日志的等级进行判断,如果是1,输出日志信息
if (level == 1) {
System.out.println(message);
}
}

public static void main(String[] args) {
    // 定义三个日志信息
    String msg1 = "法外";
    String msg2 = "狂徒";
    String msg3 = "张三";

    // 调用showLog方法,传递日志级别和日志信息
    showLog(2,msg1+msg2+msg3);
}

}


  

###### 23-05 使用Lambda优化日志案例



package day_12FunctionInterface.demo02Lambda;

/*
使用Lambda优化日志案例
Lambda的特点:延迟加载
Lambda的使用前提:必须存在函数式接口
*/
public class Demo02Lambda {
// 定义一个显示日志的方法,方法的参数传递日志的等级和MessageBuilder接口
public static void showLog(int level, MessageBuilder mb) {
// 对日志的等级进行判断,如果是1,输出日志信息
if (level == 1) {
System.out.println(mb.builderMessage());
}
}

public static void main(String[] args) {
    // 定义三个日志信息
    String msg1 = "法外";
    String msg2 = "狂徒";
    String msg3 = "张三";

    // 调用showLog方法,传递日志级别和日志信息
    showLog(1, ()-> msg1+msg2+msg3);
}

}



package day_12FunctionInterface.demo02Lambda;

@FunctionalInterface
public interface MessageBuilder {
// 定义一个拼接消息的抽象方法,返回被拼接的消息
public abstract String builderMessage();
}


  

##### 2.2 使用Lambda作为参数和返回值


###### 23-06 函数式接口作为方法的参数案例



package day_12FunctionInterface.demo03LambdaTest;

/*
java.lang.Runnable接口就是一个函数式接口
假设有一个startThread方法使用该接口作为参数,可以用Lambda进行传参
*/
public class Demo01Runnable {
// 定义一个startThread方法使用Runnable接口作为参数
public static void startThread(Runnable runnable) {
// 开启多线程
new Thread(runnable).start();
}

public static void main(String[] args) {
    startThread(()-> System.out.println(Thread.currentThread().getName() + "启动") );
}

}


  

###### 23-07 函数式接口作为方法的返回值类型案例



package day_12FunctionInterface.demo03LambdaTest;

import java.util.Arrays;
import java.util.Comparator;

/*
如果一个方法的返回值类型是一个函数式接口,那么就可以直接返回一个Lambda表达式
当需要通过一个方法来获取java.util.Comparator接口类型的对象作为排序其时,可以调用该方法获取
*/
public class Demo02Comparator {
// 定义一个方法,返回值类型使用函数式接口Comparator
public static Comparator getComparator() {
// 方法的返回值类型是一个接口,那么我们可以返回这个接口的匿名内部类
// return new Comparator() {
// @Override
// public int compare(String o1, String o2) {
// // 按照字符串的长度降序排序
// return o2.length()-o1.length();
// }
// }

    // Lambda优化
    return (o1,o2)->o2.length()-o1.length();
}

public static void main(String[] args) {
    // 创建一个字符串数组
    String[] arr = {"cj","hsg","a"};
    // 输出排序前的数组
    System.out.println(Arrays.toString(arr));
    // 调用Arrays中的sort方法对字符串数组排序
    Arrays.sort(arr,getComparator());
    // 输出排序后的数组
    System.out.println(Arrays.toString(arr));
}

}


  

#### 第三章 常用函数式接口


##### 3.1 Supplier接口


###### 23-08 常用函数式接口-Supplier接口



package day_12FunctionInterface.demo04Supplier;

import java.util.function.Supplier;

/*
常用的函数式接口
java.util.function.Supplier 接口仅包含一个无参的方法:T get(),用来获取一个泛型参数指定类型的对象数据

Supplier 接口被称之为生产型接口,指定接口的泛型是什么类型,那么接口中的get方法就会生产什么类型的数据
*/
public class Demo01Supplier {
// 定义一个方法,方法的参数传递Supplier接口,泛型指定String,get方法就会返回String
public static String getString(Supplier supplier){
return supplier.get();
}

public static void main(String[] args) {

// String s = getString(() -> {
// // 生产一个字符串并返回
// return “胡歌”;
// });

    // 优化
    String s = getString(() -> "胡歌");
    System.out.println(s);
}

}


  

##### 3.2 练习:求数组元素最大值


题目  
 解答


###### 23-09 常用函数式接口-Supplier接口练习-求数组元素最大值



package day_12FunctionInterface.demo04Supplier;

import java.util.function.Supplier;

/*
练习:求数组元素的最大值
使用Supplier接口作为方法参数类型,通过Lambda表达式求出int数组中的最大值
提示:接口的泛型请使用java.lang.Integer类
*/
public class Demo02Test {
// 定义一个方法,用于获取int类型数组中元素的最大值,方法的参数传递Supplier接口,泛型使用Integer
public static int getMax(Supplier supplier) {
return supplier.get();
}

public static void main(String[] args) {
    int[] arr = {4,26,56,45,7,2};
    int maxNum = getMax(() -> {
        // 获取数组的最大值并返回
        int max = arr[0];
        for (int i = 0; i < arr.length; i++) {
            if (arr[i] > max) {
                max = arr[i];
            }
        }
        return max;
    });
    System.out.println("最大值是" + maxNum);
}

}


  

##### 3.3 Consumer接口


抽象方法accept  
 默认方法andThen


###### 23-10 常用函数式接口-Consumer接口



package day_12FunctionInterface.demo05Consumer;

import java.util.function.Consumer;

/*
java.util.function.Consumer接口则正好与Supplier相反
它不是生产一个数据,而是消费一个数据,其数据类型由泛型决定
Consumer接口中包含抽象方法void accept(T t),意为消费一个指定泛型的数据

Consumer接口是一个消费型接口,泛型指定什么类型,就可以使用accept方法消费什么类型的数据
具体消费(使用),需要自定义(输出,计算…)
*/
public class Demo01Consumer {
public static void getConsumer(Consumer consumer, String name) {
consumer.accept(name);
}

public static void main(String[] args) {
    getConsumer(name->{
        // 消费方式:直接输出字符
        System.out.println(name);

        // 消费方式:把字符串进行反转输出
        String s = new StringBuffer(name).reverse().toString();
        System.out.println(s);
    },"张三");
}

}


  

###### 23-11 常用函数式接口-Consumer接口的默认方法andThen



package day_12FunctionInterface.demo05Consumer;

import java.util.function.Consumer;

/*
Consumer接口的默认方法andThen
作用:需要两个Consumer接口,可以把两个Consumer接口组合到一起,再对数据进行消费

例如:
Consumer con1 等价于 con1.andThen(con2).accept(s)谁写前面谁先消费
Consumer con2
String s = “Hello”
con1.accept(s)
con2.accept(s)

*/
public class Demo02AndThen {
public static void method(String s, Consumer consumer1, Consumer consumer2) {
// consumer1.accept(s);
// consumer2.accept(s);

    // 使用andThen方法把两个接口连接到一起再消费数据
    consumer1.andThen(consumer2).accept(s);
}

public static void main(String[] args) {
    method("xnCzo", (s)->{
        // 把字符串转换为大写输出
        System.out.println(s.toUpperCase());
    },(s)->{
        // 把字符串转换为小写输出
        System.out.println(s.toLowerCase());
    });
}

}


  

##### 3.4 练习:格式化打印信息


题目  
 解答


###### 23-12 常用函数式接口-Consumer接口练习-字符串拼接输出



package day_12FunctionInterface.demo05Consumer;

import java.util.function.Consumer;

/*
练习:
字符串数组中存有多条信息,请按照格式“姓名:xx。性别:xx。"的格式将信息打印出来
要求将打印姓名的动作作为第一个Consumer接口的Lambda实例
要求将打印性别的动作作为第二个Consumer接口的Lambda实例
将两个Consumer接口按照顺序拼接到一起
*/
public class Demo03Test {
public static void printMessage(String[] arr, Consumer con1, Consumer con2){
for (String s : arr) {
con1.andThen(con2).accept(s);
}
}

public static void main(String[] args) {
    // 定义一个字符串类型的数组
    String[] arr = {"法外,20","狂徒,39","张三,40"};
    printMessage(arr,(s)->{
        String[] strings = s.split(",");
        System.out.print("姓名:" + strings[0] + "。");
    },(s)->{
        String[] strings = s.split(",");
        System.out.println("性别:" + strings[1] + "。");
    });
}

}


  

##### 3.5 Predicate接口


抽象方法 test  
 默认方法and  
 默认方法or  
 默认方法negate


###### 23-13 常用函数式接口-Predicate接口



package day_12FunctionInterface.demo06Predicate;

import java.util.function.Predicate;

/*
java.util.function.Predicate 接口
作用:对某种数据类型的数据进行判断,结果返回一个boolean值

Predicate接口中包含一个抽象方法
boolean test(T t) 用来对指定数据类型数据进行判断的方法
结果:
符合条件 true
不合符条件 false
*/
public class Demo01Predicate {
// 定义一个方法,参数传递一个String类型的字符串,传递一个Predicate接口,泛型使用String,使用方法test对字符串进行判断,并把判断的结果进行返回
public static boolean judge(String s, Predicate p) {
return p.test(s);
}

public static void main(String[] args) {
    boolean b = judge("cnxo", (s) -> s.length() == 3);
    System.out.println(b);
}

}


  

###### 23-14 常用函数式接口-Predicate接口-默认方法and



package day_12FunctionInterface.demo06Predicate;

import java.util.function.Predicate;

/*

img
img
img

既有适合小白学习的零基础资料,也有适合3年以上经验的小伙伴深入学习提升的进阶课程,涵盖了95%以上大数据知识点,真正体系化!

由于文件比较多,这里只是将部分目录截图出来,全套包含大厂面经、学习笔记、源码讲义、实战项目、大纲路线、讲解视频,并且后续会持续更新

需要这份系统化资料的朋友,可以戳这里获取

tem.out.println(b);
}
}


  

###### 23-14 常用函数式接口-Predicate接口-默认方法and



package day_12FunctionInterface.demo06Predicate;

import java.util.function.Predicate;

/*

[外链图片转存中…(img-Qb8enDAa-1714851316306)]
[外链图片转存中…(img-LeRs1DaC-1714851316307)]
[外链图片转存中…(img-8Y4qb2mz-1714851316307)]

既有适合小白学习的零基础资料,也有适合3年以上经验的小伙伴深入学习提升的进阶课程,涵盖了95%以上大数据知识点,真正体系化!

由于文件比较多,这里只是将部分目录截图出来,全套包含大厂面经、学习笔记、源码讲义、实战项目、大纲路线、讲解视频,并且后续会持续更新

需要这份系统化资料的朋友,可以戳这里获取

  • 28
    点赞
  • 11
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值