Java 8 函数式接口,Function,Consumer,Predicate 接口的学习

本篇博文非原创。转载自http://blog.youkuaiyun.com/pzxwhc/article/details/48314039

感谢大佬:Sauron1,东西十分详细,学习了~


转载摘抄主要是为了自己积累知识 :)


包括:

一. Function 接口的使用

二. Consumer 接口的使用 和 Function 接口的区别

三. Predicate 接口的使用


一. Function 接口的使用
         该接口目前发布在 java.util.function 包中。接口中主要有方法:
R apply(T t);  

 将Function对象应用到输入的参数上,然后返回计算结果。
Demo:
         如果 字符串为空,显示 "字符串不能为空",如果字符串长度大于3,显示 "字符串过长"。那么按照普通的方式,我就就是两个 if 语句。现在使用Function 接口如下:
public class Test {  
    public static void main(String[] args) throws InterruptedException {  
        String name = "";  
        String name1 = "12345";  
        System.out.println(validInput(name, inputStr -> inputStr.isEmpty() ? "名字不能为空":inputStr));  
        System.out.println(validInput(name1, inputStr -> inputStr.length() > 3 ? "名字过长":inputStr));  
    }  
      
    public static String validInput(String name,Function<String,String> function) {  
        return function.apply(name);  
    }  
}  

解释:
  1. 定义 validInput 方法,传入 function 接口,然后在该方法中定义 function.apply(name),也就是说,传入一个 name 参数,应用某些规则,返回一个结果,至于是什么规则,先不定义。
  2. 在main 方法中调用 validInput(name,inputStr ...),这里我们定义规则,利用lambda 表达式, 规则是:传入一个 inputStr 字符串,如果为空,返回 xx;否则 返回 xx。
从上述的例子可以看出,其实 这种方式 比起 两个 if 语句 看起来要爽一点(个人感觉)。

二. Consumer 接口的使用 以及 和Function 接口 的区别
         该接口表示 接受单个输入参数并且没有返回值的操作。接口里面重要方法为:
void accept(T t);  

2.1 使用
         还是如上的例子,Demo代码如下:
public class Test {  
    public static void main(String[] args) throws InterruptedException {  
        String name = "";  
        String name1 = "12345";  
          
        validInput(name, inputStr ->    
                System.out.println(inputStr.isEmpty() ? "名字不能为空":"名字正常"));  
        validInput(name1, inputStr ->  
                System.out.println(inputStr.isEmpty() ? "名字不能为空":"名字正常"));  
          
    }  
    public static void validInput(String name,Consumer<String> function) {  
        function.accept(name);  
    }  
}  

2.2 Consumer 和 Function 的区别
         主要就是 Consumer 接口没有返回值, Function 接口有返回值。
三. Predicate 接口的使用
         Predicate 方法 表示 判断 输入的对象是否 符合某个条件。主要方法如下:
boolean test(T t);  

Demo,还是如上面的例子:
public class Test {  
    public static void main(String[] args) throws InterruptedException {  
        String name = "";  
        String name1 = "12";  
        String name2 = "12345";  
          
        System.out.println(validInput(name,inputStr ->  !inputStr.isEmpty() &&  inputStr.length() <= 3 ));  
        System.out.println(validInput(name1,inputStr ->  !inputStr.isEmpty() &&  inputStr.length() <= 3 ));  
        System.out.println(validInput(name2,inputStr ->  !inputStr.isEmpty() &&  inputStr.length() <= 3 ));  
          
    }  
    public static boolean validInput(String name,Predicate<String> function) {  
        return function.test(name);  
    }  
}  

输出为:
false  
true  
false  

总结:
  1. Function:接受一个参数,返回一个参数。
  2. Consumer:接受一个参数,不返回参数。
  3. Predicate:用于测试是否符合条件。
参考:
1.Function接口 - Java8中 java.util.function包下的函数式接口:   http://ifeve.com/jjava-util-function-java8/
2.Predicate接口和Consumer接口 -  Java8中 java.util.function包下的函数式接口:   http://ifeve.com/predicate-and-consumer-interface-in-java-util-function-package-in-java-8/

### 解决 PP-OCRv4 出现的错误 当遇到 `WARNING: The pretrained params backbone.blocks2.0.dw_conv.lab.scale not in model` 这样的警告时,这通常意味着预训练模型中的某些参数未能匹配到当前配置下的模型结构中[^2]。 对于此问题的一个有效解决方案是采用特定配置文件来适配预训练权重。具体操作方法如下: 通过指定配置文件 `ch_PP-OCRv4_det_student.yml` 并利用已有的最佳精度预训练模型 (`best_accuracy`) 来启动训练过程可以绕过上述不兼容的问题。执行命令如下所示: ```bash python3 tools/train.py -c configs/det/ch_PP-OCRv4/ch_PP-OCRv4_det_student.yml ``` 该方案不仅解决了参数缺失带来的警告,还能够继续基于高质量的预训练成果进行微调,从而提升最终检测效果。 关于蒸馏的概念,在机器学习领域内指的是将大型复杂网络(teacher 模型)的知识迁移到小型简单网络(student 模型)。这里 student 和 teacher 的关系是指两个不同规模或架构的神经网络之间的指导与被指导的关系;其中 teacher 已经经过充分训练并具有良好的性能,而 student 则试图模仿前者的行为模式以达到相似的效果但保持更高效的计算特性。 至于提到的 `Traceback` 错误信息部分,由于未提供具体的跟踪堆栈详情,难以给出针对性建议。不过一般而言,这报错往往涉及代码逻辑错误或是环境配置不当等问题。为了更好地帮助定位和解决问题,推荐记录完整的异常日志,并仔细检查最近修改过的代码片段以及确认依赖库版本的一致性。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值