当前位置: 首页 > news >正文

Java中的函数式编程入门

Java中的函数式编程入门

大家好,我是免费搭建查券返利机器人省钱赚佣金就用微赚淘客系统3.0的小编,也是冬天不穿秋裤,天冷也要风度的程序猿!今天我来为大家介绍一下Java中的函数式编程。随着Java 8的发布,函数式编程成为Java开发者的一项重要技能。函数式编程不仅简化了代码,还提升了代码的可读性和可维护性。本文将带你入门Java中的函数式编程,主要涵盖Lambda表达式、函数式接口、方法引用和Stream API。

什么是函数式编程?

函数式编程是一种编程范式,它将计算过程视为数学函数的计算。函数式编程的核心概念包括:

  • 不可变性:数据一旦创建就不能改变。
  • 无副作用:函数调用不会改变外部状态。
  • 高阶函数:函数可以作为参数传递给其他函数或作为返回值返回。

Lambda表达式

Lambda表达式是Java 8引入的一个重要特性,它使得可以将函数作为一等公民来对待,从而使代码更加简洁和易读。Lambda表达式的语法格式如下:

(parameters) -> expression
或
(parameters) -> { statements; }

例如,我们有一个简单的接口MyFunction

@FunctionalInterface
interface MyFunction {int apply(int x, int y);
}

我们可以使用Lambda表达式来实现这个接口:

MyFunction add = (x, y) -> x + y;
System.out.println(add.apply(5, 3)); // 输出 8

函数式接口

函数式接口是仅包含一个抽象方法的接口,这种接口可以隐式转换为Lambda表达式。Java 8提供了几个内置的函数式接口,例如FunctionConsumerSupplierPredicate等。我们也可以自定义函数式接口:

@FunctionalInterface
interface MyFunction {int apply(int x, int y);
}

方法引用

方法引用是Lambda表达式的简化形式,用于直接引用已有的方法。方法引用有四种形式:

  1. 引用静态方法:ClassName::staticMethodName
  2. 引用实例方法:instance::instanceMethodName
  3. 引用特定对象的实例方法:ClassName::instanceMethodName
  4. 引用构造方法:ClassName::new

例如,我们有一个静态方法sum

public class MathUtils {public static int sum(int a, int b) {return a + b;}
}

我们可以使用方法引用来引用这个静态方法:

MyFunction add = MathUtils::sum;
System.out.println(add.apply(5, 3)); // 输出 8

Stream API

Stream API是Java 8引入的一组用于处理集合数据的新工具,它提供了一种声明性方式来处理数据流。Stream操作分为中间操作和终端操作。中间操作包括filtermapsorted等,这些操作返回一个新的Stream;终端操作包括forEachcollectreduce等,这些操作返回一个结果或副作用。

以下是一个使用Stream API的示例:

List<String> names = Arrays.asList("Alice", "Bob", "Charlie", "David");
List<String> filteredNames = names.stream().filter(name -> name.startsWith("A")).collect(Collectors.toList());
System.out.println(filteredNames); // 输出 [Alice]

在这个示例中,我们首先创建了一个包含多个名字的列表,然后使用stream方法将列表转换为Stream对象。接着,我们使用filter中间操作过滤出以"A"开头的名字,最后使用collect终端操作将结果收集到一个新的列表中。

实战示例:使用函数式编程实现简单的事件处理器

为了更好地理解Java中的函数式编程,我们来实现一个简单的事件处理器。首先,我们定义一个事件接口和具体的事件类:

@FunctionalInterface
interface EventHandler {void handle(String event);
}class ClickEvent {private String message;public ClickEvent(String message) {this.message = message;}public String getMessage() {return message;}
}

接下来,我们定义一个事件处理器的管理类:

class EventProcessor {private List<EventHandler> handlers = new ArrayList<>();public void registerHandler(EventHandler handler) {handlers.add(handler);}public void processEvent(String event) {for (EventHandler handler : handlers) {handler.handle(event);}}
}

我们可以使用Lambda表达式和方法引用来注册事件处理器:

public class Main {public static void main(String[] args) {EventProcessor processor = new EventProcessor();processor.registerHandler(event -> System.out.println("Handling event: " + event));processor.registerHandler(System.out::println);processor.processEvent("Button clicked!");}
}

在这个示例中,我们创建了一个EventProcessor实例,并注册了两个事件处理器。第一个处理器使用Lambda表达式打印事件消息,第二个处理器使用方法引用直接打印事件。最后,我们触发一个事件,两个处理器分别处理并输出结果。

结论

通过本文的介绍,我们了解了Java中的函数式编程的基础概念和一些重要特性,如Lambda表达式、函数式接口、方法引用和Stream API。函数式编程使得代码更加简洁、易读和易维护。希望通过这些示例,你能够对Java中的函数式编程有一个初步的了解,并在实际开发中应用这些知识,编写出更加优雅的代码。

相关文章:

Java中的函数式编程入门

Java中的函数式编程入门 大家好&#xff0c;我是免费搭建查券返利机器人省钱赚佣金就用微赚淘客系统3.0的小编&#xff0c;也是冬天不穿秋裤&#xff0c;天冷也要风度的程序猿&#xff01;今天我来为大家介绍一下Java中的函数式编程。随着Java 8的发布&#xff0c;函数式编程成…...

idea 自动生成序列化数字

目标&#xff1a;当类继承Serializable后自动生成序列化Uid 网上查了很多说勾选class without ‘serialVersionUID’ 但是我勾选没用 最后发现&#xff0c;我勾选的是Serialization issues里面的配置&#xff0c;要勾选的是JVM languages下的 如下图所示&#xff0c;记录一下…...

Java数据结构算法(最长递增序列二分查找)

前言: 最长递增子序列&#xff08;Longest Increasing Subsequence, LIS&#xff09;是指在一个给定的序列中&#xff0c;找到一个最长的子序列&#xff0c;使得这个子序列中的元素是单调递增的。子序列不要求在原序列中连续。 实现原理 使用一个 tails 列表&#xff0c;其中…...

编译VTK静态库

编译VTK静态库遇到问题 vtkCommonCore-9.3d.lib(vtkSMPToolsAPI.obj) : error LNK2019: unresolved external symbol "public: bool __cdecl vtk::detail::smp::vtkSMPToolsImpl<1>::IsParallelScope(void)" (?IsParallelScope?$vtkSMPToolsImpl$00smpdetai…...

Python中的@property装饰器:深入理解与应用

Python中的property装饰器&#xff1a;深入理解与应用 在Python中&#xff0c;property装饰器是一个强大的工具&#xff0c;它允许我们将方法作为属性来访问&#xff0c;使得代码更加简洁、清晰&#xff0c;并提供了更好的封装性。本文将深入探讨property装饰器的工作原理、应…...

springCloudalibabaAI孵化(一)

目录 1、what 1、简介 2、核心概念 3、高级特性 Prompt 和 AiResponse 4、功能 2、How 1、前言 2、在项目 pom.xml 中加入 2023.0.1.0 版本 Spring Cloud Alibaba 依赖&#xff1a; 3、在 配置文件中加入以下配置&#xff1a;application.yml 4、编写聊天服务实现类&a…...

【封装】Unity编辑器模式GUID加载资源

介绍 在编辑器模式下通过GUID获取工程目录下的指定资源的接口工具封装 工具原理 借助AssetDatabaseAPI FindAssets : 获取 GUID GUIDToAssetPath : 通过GUID获取路径LoadAssetAtPath<T>: 通过路径加载资源 代码&#xff1a; public static class GetAssetUtil {pub…...

安装 Docker 环境(通过云平台创建一个实例实现)

目录 1. 删除原有 yum 2. 手动配置 yum 源 3. 删除防火墙规则 4. 保存防火墙配置 5. 修改系统内核。打开内核转发功能。 6. 安装 Docker 7. 设置本地镜像仓库 8.重启服务 1. 删除原有 yum rm -rfv /etc/yum.repos.d/* 2. 手动配置 yum 源 使用 centos7-1511.iso 和 Xi…...

MySQL之可扩展性(六)

可扩展性 向外扩展 12.重新均衡分片数据 如有必要&#xff0c;可以通过在分片间移动数据来达到负载均衡。举个例子&#xff0c;许多读者可能听一些大型图片分享网站或流行社区网站的开发者提到过用于分片间移动用户数据的工具。在分片间移动数据的好处很明显。例如&#xff…...

C++ | Leetcode C++题解之第202题快乐数

题目&#xff1a; 题解&#xff1a; class Solution { public:int ProductSum(int n){int sum 0;while(n){int temp n % 10;sum temp*temp;n / 10;}return sum;}bool isHappy(int n) {int slow n,fast n;// 快慢指针&#xff0c;找环的相遇位置do{slow ProductSum(slow)…...

NIST网络安全框架体系应用

NIST网络安全框架体系应用 NIST网络安全框架&#xff08;NIST Cybersecurity Framework, NIST CSF&#xff09;由美国国家标准与技术研究院&#xff08;NIST&#xff09;发布&#xff0c;是一套广泛应用于各种组织的网络安全管理指南。该框架通过识别、保护、检测、响应和恢复…...

【LeetCode】七、树、堆、图

文章目录 1、树结构2、二叉树3、二叉树的遍历4、堆结构&#xff08;Heap&#xff09;5、堆化6、图 1、树结构 节点、根节点、叶子节点&#xff1a; 高度、深度、层三者的示意图&#xff1a; 2、二叉树 相比其他树&#xff0c;二叉树即每个节点最多两个孩子&#xff08;两个分…...

FPGA PCIe加载提速方案

目录 1.bit流压缩 2.flash加载速度 3.Tandem模式 1.bit流压缩 set_property BITSTREAM.GENERAL.COMPRESS TRUE [current_design] 2.flash加载速度 打开bitstream setting&#xff0c;设置SPI的线宽和速率&#xff08;线宽按原理图设置&#xff0c;速率尽可能高&#xff09…...

Hi3861 OpenHarmony嵌入式应用入门--轮询按键

本篇介绍使用轮询方式读取gpio状态来判断按键状态。 原理图如下 GPIO API API名称 说明 hi_u32 hi_gpio_init(hi_void); GPIO模块初始化 hi_u32 hi_io_set_pull(hi_io_name id, hi_io_pull val); 设置某个IO上下拉功能。 hi_u32 hi_gpio_set_dir(hi_gpio_idx id, hi_gpi…...

js,uni 自定义 时间选择器 vue2

<template><view class"reserve-time-box"><view class"title">选择时间</view><view class"date-box"><view class"date-scroll-box" :style"{ width : ${dataTimeWidth}rpx }"><v…...

搜索引擎的原理与相关知识

搜索引擎是一种网络服务&#xff0c;它通过互联网帮助用户找到所需的信息。搜索引擎的工作原理主要包括以下几个步骤&#xff1a; 网络爬虫&#xff08;Web Crawler&#xff09;&#xff1a;搜索引擎使用网络爬虫&#xff08;也称为蜘蛛或机器人&#xff09;来遍历互联网&#…...

React:tabs或标签页自定义右击菜单内容,支持内嵌iframe关闭菜单方案

React&#xff1a;tabs或标签页自定义右击菜单内容&#xff0c;支持内嵌iframe关闭菜单方案 不管是react、vue还是原生js&#xff0c;原理是一样的。 注意如果内嵌iframe情况下&#xff0c;iframe无法使用事件监听&#xff0c;但是可以使用iframe的任何点击行为都会往父级wind…...

Taro +vue3 中的微信小程序中的分享

微信小程序 右上角分享 的触发 以及配 useShareAppMessage(() > {return {title: "电影属全国通兑券",page: /pages/home/index,imageUrl: "http:///chuanshuo.jpg",};}); 置 就是Taro框架中提供的一个分享Api 封装好的...

视频监控EasyCVR视频汇聚/智能边缘网关:EasySearch无法探测到服务器如何处理?

安防监控EasyCVR智能边缘网关/视频汇聚网关/视频网关属于软硬一体的边缘计算硬件&#xff0c;可提供多协议&#xff08;RTSP/RTMP/国标GB28181/GAT1400/海康Ehome/大华/海康/宇视等SDK&#xff09;的设备接入、音视频采集、视频转码、处理、分发等服务&#xff0c;系统具备实时…...

openlayer 鼠标点击船舶,打开船舶简单弹框

背景&#xff1a; 对创建的地图对象&#xff0c;可以添加上监听事件&#xff0c;常用的有&#xff1a;地图点击事件、鼠标移动事件。 通过监听这些事件&#xff0c;又可以区分不同图层的不同要素&#xff0c;获取不同数据&#xff1b; 根据这些数据&#xff0c;又可以发起网络请…...

毕业季论文救星:深度解析百考通AI如何智能攻克文献综述与开题报告

又到一年毕业季&#xff0c;无数莘莘学子在为自己学术生涯的“终极答卷”——毕业论文而挑灯夜战。其中&#xff0c;文献综述的浩如烟海与开题报告的千头万绪&#xff0c;无疑是横亘在大多数同学面前的两座大山。你是否也曾面对海量文献不知如何筛选梳理&#xff1f;是否为构建…...

从RS-485到MQTT:手把手教你为BMS Modbus设备搭建物联网网关(Node-RED实战)

从RS-485到MQTT&#xff1a;手把手教你为BMS Modbus设备搭建物联网网关&#xff08;Node-RED实战&#xff09; 当工业现场的BMS设备还在使用Modbus-RTU协议时&#xff0c;如何让这些"信息孤岛"融入现代物联网架构&#xff1f;这个问题困扰着许多能源管理系统工程师。…...

Flash闪存技术

1 Mask ROM Cartridges: ROM卡带, Character ROM (CHR ROM) and the Program ROM (PRG ROM). Both of them are Mask ROM. SRAM or EEPROM: game status saving. Moto 6502: 6502 -> ST7 -> STM82 HDD Low-level formatting 低级格式化历史&#xff1a;HDD一个完整扇区包…...

实测!用DeepSeek R1和通义千问Max分别写代码、解数学题,结果有点意外

DeepSeek R1与通义千问Max实战对比&#xff1a;当代码遇上数学题 上周我在开发一个需要同时处理算法优化和复杂数学计算的个人项目时&#xff0c;突然萌生了一个想法&#xff1a;为什么不把市面上最火的两个AI编程助手——DeepSeek R1和通义千问Max拉出来比一比&#xff1f;作…...

51单片机+DAC0832信号发生器实战:从硬件搭建到波形调试全记录(附避坑指南)

51单片机DAC0832信号发生器实战&#xff1a;从硬件搭建到波形调试全记录&#xff08;附避坑指南&#xff09; 在电子设计领域&#xff0c;信号发生器是工程师和爱好者不可或缺的工具。传统商用设备虽然功能强大&#xff0c;但对于学习嵌入式系统和数模转换原理而言&#xff0c;…...

全志T3核心板DDR初始化失败:从ZQ校准误导到VREF电压偏差的排查实录

1. 问题现象与初步排查 那天早上刚到实验室&#xff0c;测试组的同事就急匆匆跑过来&#xff1a;"哥&#xff0c;又有三台设备启动不了&#xff0c;uboot都没跑起来&#xff01;"我接过设备一看&#xff0c;果然又是熟悉的ZQ校准错误提示&#xff0c;这已经是本周第五…...

Pixel Fashion Atelier部署教程:华为云ModelArts平台上的Ascend NPU适配实践

Pixel Fashion Atelier部署教程&#xff1a;华为云ModelArts平台上的Ascend NPU适配实践 1. 项目概述 Pixel Fashion Atelier是一款基于Stable Diffusion与Anything-v5的图像生成工作站&#xff0c;采用独特的像素艺术风格界面设计。与传统AI工具不同&#xff0c;它将图像生成…...

生成式 AI 赋能下钓鱼攻击的技术异化与防御体系构建

摘要 生成式人工智能在文本创作、语义理解与内容生成领域的快速落地&#xff0c;在提升生产效率的同时&#xff0c;也被不法分子用于网络钓鱼攻击的智能化升级。路透社与哈佛大学联合测试显示&#xff0c;主流大语言模型在特定提示词绕过机制下可生成高仿真钓鱼邮件&#xff0c…...

Double Q-learning实战:如何用Python解决过估计问题(附代码示例)

Double Q-learning实战&#xff1a;如何用Python解决过估计问题&#xff08;附代码示例&#xff09; 强化学习中的Q-learning算法因其简洁高效而广受欢迎&#xff0c;但在某些场景下会出现严重的过估计问题。本文将深入探讨这一现象的本质&#xff0c;并手把手教你用Python实现…...

FPGA做信号处理,你的浮点加减法拖后腿了吗?聊聊Vivado Floating-point IP核的性能调优

FPGA信号处理中浮点加减法的性能瓶颈与Vivado Floating-point IP核深度调优 在雷达脉冲压缩、波束成形等实时信号处理系统中&#xff0c;浮点运算单元往往是制约整体性能的关键瓶颈。许多工程师在完成基础功能验证后&#xff0c;常发现系统吞吐量不达标或时序无法收敛&#xff…...