Java-8函数式编程设计-Functional-Interface
Java 8函数式编程设计-Functional-Interface
我自己的理解,函数式编程对用户最大的价值是促使开发者养成模块化编程的习惯,代码可读性和维护性提高很多。
通过阅读JDK 8的 java.util.function 和
java.util.stream 包源码,意在理解Java的函数式接口设计。
读后自己的理解:Java函数式编程的核心是将最基础的数学函数抽象成接口对象,可在已有的接口上进行积木拼插组合,形成完整地类型转换系统。最基础的数学函数包括一元函数、谓词、二元函数、运算符计算,对应的Java接口分别是Function、Predicate、BiFunction、BinaryOperator。
源码阅读笔记:jdk-8-Functional-Interface
函数式接口API
- @FunctionalInterface
- Functional interfaces
- Function
- Consumer
- Predicate
- Supplier
- 数据流特性和操作
- BaseStream
- Stream
- 使用示例
@FunctionalInterface
- 函数式接口注解
- 从概念上讲,函数式接口都只有一个抽象方法。
- 请注意,可以使用Lambda表达式、方法引用和构造器引用创建函数式接口的实例。
Functional interfaces
- 函数式接口提供lambda表达式和方法引用的目标类型
- 每个函数式接口有一个单一的抽象方法,称为函数方法
- 函数式接口可以匹配或适配为lambda表达式的参数和返回类型
- 函数式接口可以在多个上下文中提供一个目标类型,如赋值上下文、方法调用上下文、转换上下文
- 函数式接口往往代表抽象的概念,如函数、操作、谓词
- 可扩展的命名约定
- 基本的一元函数:Function、Consumer、Predicate、Supplier
- 二元函数:BiFunction、BiConsumer、BiPredicate
- 扩展的运算符:UnaryOperator、BinaryOperator
- 泛型->基本类型:int、long、double
一元函数
Function<T, R>
- 从T到R的一元映射函数,接受一个参数并产生一个结果的一元函数 (类型转换函数)
- R apply(T t)
- 组合函数
- compose(before):V -> T -> R
- andThen(after):T -> R -> V
- 基本类型的参数:IntFunction、LongFunction、DoubleFunction
- 基本类型的结果:ToIntFunction、ToLongFunction、ToDoubleFunction
- 基本类型的参数和结果:IntToLongFunction、IntToDoubleFunction
Consumer<T>
- 从T到void的一元函数,接受一个入参但不返回任何结果的操作
- void accept(T t)
- andThen(after):N个消费者模式,多次消费的场景
- 基本类型的参数:IntConsumer、LongConsumer、DoubleConsumer
Predicate<T>
- 一个参数的谓词(返回布尔值的函数)
- boolean test(T t)
- 谓词函数:and、negate、or
- 基本类型的参数:IntPredicate、LongPredicate、DoublePredicate
Supplier<T>
- 表示结果的供应商
- T get()
- 基本类型的结果:BooleanSupplier、IntSupplier、LongSupplier、DoubleSupplier
使用图表方式总结如下:
一元函数 | 方法 | 类型转换 | 组合方法 | 基本类型专用类 |
---|---|---|---|---|
Function<T, R> | R apply(T t) | T->R | compose(before)、andThen(after) | IntFunction、ToIntFunction、IntToLongFunction |
Consumer | void accept(T t) | T->void | andThen(after) | IntConsumer |
Predicate | boolean test(T t) | T->boolean | and、negate、or | IntPredicate |
Supplier | T get() | *->T | IntSupplier、BooleanSupplier |
二元函数
BiFunction<T, U, R>
- 从(T、U)到R的二元函数,接受两个参数并产生一个结果的二元函数
- R apply(T t, U u)
- 组合函数
- andThen(Function<? super R, ? extends V> after):(T, U) -> R -> V
- 基本类型的结果:ToIntBiFunction<T, U>、ToLongBiFunction<T, U>、ToDoubleBiFunction<T, U>
BiConsumer<T, U>
- 从(T、U)到void的二元函数,接受两个入参但不返回任何结果的操作
- void accept(T t, U u)
- 基本类型的参数:ObjIntConsumer、ObjLongConsumer、ObjDoubleConsumer
BiPredicate<T, U>
- 两个参数的谓词(返回布尔值的函数)
- boolean test(T t, U u)
- 谓词函数:and、negate、or
使用图表方式总结如下:
二元函数 | 方法 | 类型转换 | 组合方法 | 基本类型专用类 |
---|---|---|---|---|
BiFunction<T, U, R> | R apply(T t, U u) | (T、U)->R | andThen(Function after) | ToIntBiFunction<T, U> |
BiConsumer<T, U> | void accept(T t, U u) | (T、U)->void | andThen(after) | ObjIntConsumer |
BiPredicate<T, U> | boolean test(T t, U u) | (T、U)->boolean | and、negate、or |
扩展的运算符
UnaryOperator<T>
- 一元运算符(单个操作数,生产与操作数类型相同的结果)
- 继承自Function<T, T>
- 基本类型的运算符:IntUnaryOperator、LongUnaryOperator、DoubleUnaryOperator
BinaryOperator<T>
- 二元运算符(两个相同类型的操作数,生产与操作数类型相同的结果)
- 继承自BiFunction<T, T, T>
- 基本类型的运算符:IntBinaryOperator、LongBinaryOperator、DoubleBinaryOperator
运算符 | 父类 | 组合方法 | 基本类型专用类 |
---|---|---|---|
UnaryOperator | Function<T, T> | IntUnaryOperator: int applyAsInt(int operand) | |
BinaryOperator | BiFunction<T, T, T> | minBy、maxBy | IntBinaryOperator: int applyAsInt(int left, int right) |
数据流操作
BaseStream<T,S extends BaseStream<T,S>>
数据流操作特性
- 顺序流
- 并行流
- 拆分器
- 关闭数据流(数据流管道)
Stream<T>
数据流
- 中间操作,返回
Stream<T>
- filter
- distinct
- map
- flatMap
- peek
- 终结操作,返回结果/
Optional<T>
- collect
- forEach
- reduce
- anyMatch
- findAny
- findFirst
- count
- max
- min
使用示例
Optional<T>
单值数据流
- 可能包含null值的容器对象,包装方法的返回结果
- empty()、of(T value)、ofNullable(T value)
- isPresent()、get()
- void ifPresent(Consumer<? super T> consumer)
- Optional filter(Predicate<? super T> predicate):过滤操作
- Optional map(Function<? super T, ? extends U> mapper)
- Optional flatMap(Function<? super T, Optional> mapper)
- T orElse(T other)、T orElseGet(Supplier<? extends T> other)、T orElseThrow(Supplier<? extends X> exceptionSupplier) throws X
- 基本类型实现:OptionalInt、OptionalLong、OptionalDouble
- 使用模式:
- Optional.ifPresent(consumer)
- Optional.filter(predicate).flatMap(mapper)
- Optional.filter(predicate).map(mapper)
祝大家玩得开心!ˇˍˇ
简放,杭州
相关文章:
Java-8函数式编程设计-Functional-Interface
Java 8函数式编程设计-Functional-Interface 我自己的理解,函数式编程对用户最大的价值是促使开发者养成模块化编程的习惯,代码可读性和维护性提高很多。 通过阅读JDK 8的 java.util.function 和 java.util.stream 包源码,意在理解Java的函数…...
Linux TCP 参数设置
文章目录 Linux TCP 参数设置参考 Linux TCP 参数设置 查询tcp相关内核参数 sysctl -a|grep ipv4|grep -i --color tcp[rootlocalhost ~]# sysctl -a|grep ipv4|grep -i --color tcp sysctl: reading key "net.ipv6.conf.all.stable_secret" sysctl: reading key &…...
Dubbo之消费端服务RPC调用
在消费端服务是基于接口调用Provider端提供的服务,所以在消费端并没有服务公共接口的实现类。 使用过程中利用注解DubboReference将目标接口作为某个类的字段属性,在解析该类时获取全部字段属性并单独关注解析存在注解DubboReference的字段属性。通过步…...

报表控件Stimulsoft 新版本2024.1中,功能区工具栏新功能
今天,我们将讨论Stimulsoft Reports、Dashboards 和 Forms 2024.1版本中的一项重要创新 - 在一行中使用功能区工具栏的能力。 Stimulsoft Ultimate (原Stimulsoft Reports.Ultimate)是用于创建报表和仪表板的通用工具集。该产品包括用于WinF…...

零样本带解释性的医学大模型
带解释性的医学大模型 提出背景解法拆解方法的原因对比以前解法 零样本带解释性的医学大模型如何使用CLIP模型和ChatGPT来进行零样本医学图像分类用特定提示查询ChatGPT所生成的医学视觉特征描述相似性得分在不同症状上的可视化,用于解释模型的预测注意力图的可视化…...

英文输入法(C 语言)
题目来自于博主算法大师的专栏:最新华为OD机试C卷AB卷OJ(CJavaJSPy) https://blog.csdn.net/banxia_frontend/category_12225173.html 题目 主管期望你来实现英文输入法单词联想功能,需求如下: 依据用户输入的单词前…...
万众一心 · 喜赢未来,2023宇凡微年会暨阳朔之旅
宇凡微 万众一心 喜赢未来 2024宇凡微年会暨阳朔之旅 在一起,做时间的朋友,迈向第一 前言 INTRODUCTION 感恩宇凡微过去七年砥砺路,携手宇凡微未来七年新征程。2024年1月24日~1月27日,宇凡微在广西桂林阳朔举办了以“感恩有…...

【Spring】 AOP面向切面编程
文章目录 AOP是什么?一、AOP术语名词介绍二、Spring AOP框架介绍和关系梳理三、Spring AOP基于注解方式实现和细节3.1 Spring AOP底层技术组成3.2 初步实现3.3 获取通知细节信息3.4 切点表达式语法3.5 重用(提取)切点表达式3.6 环绕通知3.7 切…...

R语言入门笔记2.6
描述统计 分类数据与顺序数据的图表展示 为了下面代码便于看出颜色参数所对应的值,在这里先集中介绍, col1是黑色,2是粉红,3是绿色,4是天蓝,5是浅蓝,6是紫红,7是黄色,…...
PS人像处理磨皮插件
PS人像处理插件 Portraiture 人像照片进行自动磨皮和平滑处理Arcsoft Portrait 3 自动化人像磨皮软件 批量处理功能DR增强插件 含有磨皮滤镜Beautify Panel 高级质感磨皮插件PT Portrait 人像检测自动完成磨皮优化Retouch4me AI智能人能磨皮美容软件 1、Retouch4me_Heal…...

类型转换(C++)
一、C语言中的类型转换 在C语言中,如果赋值运算符左右两侧类型不同,或者形参与实参类型不匹配,或者返回值类型与 接收返回值类型不一致时,就需要发生类型转化,C语言中总共有两种形式的类型转换:隐式类型 …...

2.23数据结构
单向循环链表 创建单向循环链表,创建节点 ,头插,按位置插入,输出,尾删,按位置删除功能 //main.c #include "loop_list.h" int main() {loop_p Hcreate_head();insert_head(H,12);insert_head(…...

c++笔记理解
1.封装 (1)构造函数不是必须在的 可以通过行为修改属性 (2)private和protected区别在于继承那里要学 (3)类默认是私有,struct是共有 私有的好处:控制数据的有效性,意…...

二进制部署k8s集群之cni网络插件
目录 k8s的三种网络模式 pod内容器之间的通信 同一个node节点中pod之间通信 不同的node节点的pod之间通信 flannel网络插件 flannel的三种工作方式 VxLAN host-GW UDP Flannel udp 模式 Flannel VXLAN 模式 flannel插件的三大模式的总结 calico网络插件 k8s 组网…...
二维矩阵子集的最大值
登录—专业IT笔试面试备考平台_牛客网 正好遇到了 对于一维,我们只需要贪一次 int ans -1E9; int suf -1E9; for (int i 0; i < n; i) {if (i && (a[i] - a[i - 1]) % 2 0) {suf 0;}suf std::max(suf, 0) a[i];ans std::max(ans, suf); } ans就是最大值…...

瑞_23种设计模式_装饰者模式
文章目录 1 装饰者模式(Decorator Pattern)1.1 介绍1.2 概述1.3 装饰者模式的结构 2 案例一2.1 需求2.2 代码实现 3 案例二3.1 需求3.2 代码实现 4 JDK源码解析5 总结5.1 装饰者模式的优缺点5.2 装饰者模式的使用场景5.3 装饰者模式 VS 代理模式 &#x…...

使用Python制作进度条有多少种方法?看这一篇文章就够了!
前言 偶然间刷到一个视频,说到:当程序正在运算时,会有一个较长时间的空白期,谁也不知道程序运行的进度如何,不如给他加个进度条。 于是我今个就搜寻一下,Python版的进度条都可以怎么写! 送书…...

SpringBoot-2.7.6基于SLF4J日志门面的日志框架切换
SpringBoot 没有强制性的日志记录依赖项,但 Commons Logging API 除外,它通常由 Spring Framework 的模块提供。 要使用 Logback,您需要将其包含在类路径中。 推荐的方法是您只需要通过启动器,这都取决于 . 对于 Web 应用程序 ,因为它可传递地依赖于日志记录启动器。 如果…...
MongoDB聚合运算符:$binarySize
$binarySize聚合运算符返回给定字符串或二进制数据的字节数。 语法 { $binarySize: <string or binData> }使用 <string or bindData>可以是任何能够被解析为字符串和二进制数据的表达式;如果表达式解析为null,则$binarySize也返回null&a…...

Android的ViewModel
前言 在Compose的学习中,我们在可组合函数中使用rememberSaveable保存应用数据,但这可能意味着将逻辑保留在可组合函数中或附近。随着应用体量不断变大,您应将数据和逻辑从可组合函数中移出。 而在之前的应用架构学习中&…...
C++:std::is_convertible
C++标志库中提供is_convertible,可以测试一种类型是否可以转换为另一只类型: template <class From, class To> struct is_convertible; 使用举例: #include <iostream> #include <string>using namespace std;struct A { }; struct B : A { };int main…...

Zustand 状态管理库:极简而强大的解决方案
Zustand 是一个轻量级、快速和可扩展的状态管理库,特别适合 React 应用。它以简洁的 API 和高效的性能解决了 Redux 等状态管理方案中的繁琐问题。 核心优势对比 基本使用指南 1. 创建 Store // store.js import create from zustandconst useStore create((set)…...

【网络安全产品大调研系列】2. 体验漏洞扫描
前言 2023 年漏洞扫描服务市场规模预计为 3.06(十亿美元)。漏洞扫描服务市场行业预计将从 2024 年的 3.48(十亿美元)增长到 2032 年的 9.54(十亿美元)。预测期内漏洞扫描服务市场 CAGR(增长率&…...
JVM垃圾回收机制全解析
Java虚拟机(JVM)中的垃圾收集器(Garbage Collector,简称GC)是用于自动管理内存的机制。它负责识别和清除不再被程序使用的对象,从而释放内存空间,避免内存泄漏和内存溢出等问题。垃圾收集器在Ja…...
VTK如何让部分单位不可见
最近遇到一个需求,需要让一个vtkDataSet中的部分单元不可见,查阅了一些资料大概有以下几种方式 1.通过颜色映射表来进行,是最正规的做法 vtkNew<vtkLookupTable> lut; //值为0不显示,主要是最后一个参数,透明度…...
css3笔记 (1) 自用
outline: none 用于移除元素获得焦点时默认的轮廓线 broder:0 用于移除边框 font-size:0 用于设置字体不显示 list-style: none 消除<li> 标签默认样式 margin: xx auto 版心居中 width:100% 通栏 vertical-align 作用于行内元素 / 表格单元格ÿ…...

Map相关知识
数据结构 二叉树 二叉树,顾名思义,每个节点最多有两个“叉”,也就是两个子节点,分别是左子 节点和右子节点。不过,二叉树并不要求每个节点都有两个子节点,有的节点只 有左子节点,有的节点只有…...

使用 Streamlit 构建支持主流大模型与 Ollama 的轻量级统一平台
🎯 使用 Streamlit 构建支持主流大模型与 Ollama 的轻量级统一平台 📌 项目背景 随着大语言模型(LLM)的广泛应用,开发者常面临多个挑战: 各大模型(OpenAI、Claude、Gemini、Ollama)接口风格不统一;缺乏一个统一平台进行模型调用与测试;本地模型 Ollama 的集成与前…...
智能AI电话机器人系统的识别能力现状与发展水平
一、引言 随着人工智能技术的飞速发展,AI电话机器人系统已经从简单的自动应答工具演变为具备复杂交互能力的智能助手。这类系统结合了语音识别、自然语言处理、情感计算和机器学习等多项前沿技术,在客户服务、营销推广、信息查询等领域发挥着越来越重要…...

Razor编程中@Html的方法使用大全
文章目录 1. 基础HTML辅助方法1.1 Html.ActionLink()1.2 Html.RouteLink()1.3 Html.Display() / Html.DisplayFor()1.4 Html.Editor() / Html.EditorFor()1.5 Html.Label() / Html.LabelFor()1.6 Html.TextBox() / Html.TextBoxFor() 2. 表单相关辅助方法2.1 Html.BeginForm() …...