JDK 8+新特性(Stream API、Optional、模块化等)
JDK 8+新特性(Stream API、Optional、模块化等)
一、Stream API
1.1 概述
Stream API 是 Java 8 引入的一个新的抽象概念,它允许以声明式的方式处理数据集合。Stream 不是一个数据结构,而是对数据源(如集合、数组等)进行一系列操作的管道。这些操作可以是中间操作(如过滤、映射)和终端操作(如收集、计数)。使用 Stream API 可以使代码更加简洁、易读,并且可以利用多核处理器的并行处理能力。
1.2 基本操作
中间操作
- filter:用于过滤满足条件的元素。
import java.util.Arrays;
import java.util.List;
import java.util.stream.Collectors;public class StreamFilterExample {public static void main(String[] args) {List<Integer> numbers = Arrays.asList(1, 2, 3, 4, 5, 6);List<Integer> evenNumbers = numbers.stream().filter(n -> n % 2 == 0).collect(Collectors.toList());System.out.println(evenNumbers);}
}
- map:用于将元素进行转换。
import java.util.Arrays;
import java.util.List;
import java.util.stream.Collectors;public class StreamMapExample {public static void main(String[] args) {List<Integer> numbers = Arrays.asList(1, 2, 3);List<Integer> squaredNumbers = numbers.stream().map(n -> n * n).collect(Collectors.toList());System.out.println(squaredNumbers);}
}
终端操作
- collect:用于将流中的元素收集到一个集合中。
import java.util.Arrays;
import java.util.List;
import java.util.stream.Collectors;public class StreamCollectExample {public static void main(String[] args) {List<String> words = Arrays.asList("apple", "banana", "cherry");String result = words.stream().collect(Collectors.joining(", "));System.out.println(result);}
}
- count:用于统计流中元素的数量。
import java.util.Arrays;
import java.util.List;public class StreamCountExample {public static void main(String[] args) {List<Integer> numbers = Arrays.asList(1, 2, 3, 4, 5);long count = numbers.stream().filter(n -> n > 3).count();System.out.println(count);}
}
1.3 并行流
Stream API 支持并行流,可以利用多核处理器的并行处理能力来提高性能。使用 parallelStream() 方法可以将顺序流转换为并行流。
import java.util.Arrays;
import java.util.List;public class ParallelStreamExample {public static void main(String[] args) {List<Integer> numbers = Arrays.asList(1, 2, 3, 4, 5, 6, 7, 8, 9, 10);long sum = numbers.parallelStream().mapToInt(Integer::intValue).sum();System.out.println(sum);}
}
二、Optional
2.1 概述
Optional 是 Java 8 引入的一个容器类,用于表示一个值可能存在或不存在的情况。它可以避免空指针异常(NullPointerException),使代码更加健壮。
2.2 基本用法
- 创建
Optional对象:Optional.of(T value):创建一个包含非空值的Optional对象。如果传入的值为null,会抛出NullPointerException。Optional.ofNullable(T value):创建一个可能包含null值的Optional对象。如果传入的值为null,则返回一个空的Optional对象。Optional.empty():创建一个空的Optional对象。
import java.util.Optional;public class OptionalCreationExample {public static void main(String[] args) {Optional<String> nonEmptyOptional = Optional.of("Hello");Optional<String> nullableOptional = Optional.ofNullable(null);Optional<String> emptyOptional = Optional.empty();}
}
- 判断值是否存在:
isPresent():判断Optional对象中是否包含值。ifPresent(Consumer<? super T> action):如果Optional对象中包含值,则执行指定的操作。
import java.util.Optional;public class OptionalIsPresentExample {public static void main(String[] args) {Optional<String> optional = Optional.of("Hello");if (optional.isPresent()) {System.out.println(optional.get());}optional.ifPresent(s -> System.out.println(s.toUpperCase()));}
}
- 获取值:
get():如果Optional对象中包含值,则返回该值;否则抛出NoSuchElementException。orElse(T other):如果Optional对象中包含值,则返回该值;否则返回指定的默认值。orElseGet(Supplier<? extends T> other):如果Optional对象中包含值,则返回该值;否则通过调用指定的Supplier函数获取默认值。
import java.util.Optional;public class OptionalGetValueExample {public static void main(String[] args) {Optional<String> optional = Optional.ofNullable(null);String value = optional.orElse("Default");System.out.println(value);String value2 = optional.orElseGet(() -> "Generated Default");System.out.println(value2);}
}
三、模块化(Java 9+)
3.1 概述
Java 9 引入了模块化系统(Project Jigsaw),它允许将代码组织成模块,每个模块有自己的声明性依赖和访问控制。模块化可以提高代码的可维护性、安全性和可扩展性,并且可以减少类路径的复杂性。
3.2 模块定义
在 Java 9+ 中,每个模块由一个 module-info.java 文件来定义。该文件位于模块的根目录下,用于声明模块的名称、依赖关系和导出的包。
// module-info.java
module myModule {// 声明依赖的模块requires java.base;requires anotherModule;// 导出的包exports com.example.myPackage;
}
3.3 模块的优点
- 封装性:模块可以控制哪些包对外可见,从而提高代码的封装性和安全性。
- 可维护性:模块之间的依赖关系明确,便于代码的维护和升级。
- 性能优化:模块化系统可以减少类加载的开销,提高应用程序的启动性能。
3.4 模块的使用
在编译和运行时,需要指定模块路径和主模块。例如:
# 编译模块
javac --module-path path/to/modules -d out module-info.java com/example/myPackage/MyClass.java# 运行模块
java --module-path path/to/modules -m myModule/com.example.myPackage.MyClass
四、其他 JDK 8+ 新特性
4.1 接口默认方法和静态方法
Java 8 允许在接口中定义默认方法和静态方法。默认方法使用 default 关键字修饰,为接口提供了默认的实现;静态方法使用 static 关键字修饰,可以直接通过接口名调用。
interface MyInterface {// 默认方法default void defaultMethod() {System.out.println("This is a default method.");}// 静态方法static void staticMethod() {System.out.println("This is a static method.");}
}
4.2 日期时间 API
Java 8 引入了新的日期时间 API(java.time 包),它提供了更简洁、线程安全的日期和时间处理方式。例如:
import java.time.LocalDate;
import java.time.LocalDateTime;
import java.time.LocalTime;public class DateTimeExample {public static void main(String[] args) {LocalDate currentDate = LocalDate.now();LocalTime currentTime = LocalTime.now();LocalDateTime currentDateTime = LocalDateTime.now();System.out.println("Current date: " + currentDate);System.out.println("Current time: " + currentTime);System.out.println("Current date and time: " + currentDateTime);}
}
4.3 方法引用
方法引用是 Lambda 表达式的一种简洁形式,它允许直接引用已有的方法。方法引用使用 :: 符号,常见的方法引用有:
- 静态方法引用:
ClassName::staticMethodName - 实例方法引用:
instance::instanceMethodName - 构造方法引用:
ClassName::new
import java.util.Arrays;
import java.util.List;public class MethodReferenceExample {public static void main(String[] args) {List<String> words = Arrays.asList("apple", "banana", "cherry");words.forEach(System.out::println);}
}
相关文章:
JDK 8+新特性(Stream API、Optional、模块化等)
JDK 8新特性(Stream API、Optional、模块化等) 一、Stream API 1.1 概述 Stream API 是 Java 8 引入的一个新的抽象概念,它允许以声明式的方式处理数据集合。Stream 不是一个数据结构,而是对数据源(如集合、数组等&…...
国产编辑器EverEdit - 独门暗器:自动监视剪贴板内容
1 监视剪贴板 1.1 应用场景 如果需要对剪贴板的所有历史进行记录,并进行分析和回顾,则可以使用监视剪贴板功能,不仅在EverEdit中的复制会记录,在其他应用的复制也会记录。 1.2 使用方法 新建一个空文档(重要:防止扰乱…...
贪心算法-买卖股票的最佳时机
买卖股票的最佳时机 给定一个数组 prices ,它的第 i 个元素 prices[i] 表示一支给定股票第 i 天 的价格。你只能选择 某一天 买入这只股票,并选择在 未来的某一个不同的日子 卖出该股 票。设计一个算法来计算你所能获取的最大利润。返回你可以从这笔交易…...
文本操作基础知识:正则表达式
目录 摘要: 一、语法 二、匹配模式pattern 1、普通字符[ ] 2、限定字符 3、定位字符 4、运算字符( ) 三、修饰符flags 四、各语言的正则使用 1、Python的re 参考资料: 摘要: 常用匹配:[A-C]、[^A-C]、\w、\d、\n、\r、…...
【Scrapy】Scrapy教程6——提取数据
前一小节我们拿到了页面的数据,那页面中那么多内容,我们想要其中的部分内容,该如何获取呢?这就需要对我们下载到的数据进行解析,提取出来想要的数据,这节就讲讲如何提取数据。 引入 我们编辑保存下来的shouye.html文件看下,发现这是什么鬼,全是如下图的代码。 没错…...
PHP 网络编程介绍
PHP 学习资料 PHP 学习资料 PHP 学习资料 在当今数字化时代,网络编程是开发各类应用必不可少的技能。PHP 作为一门广泛应用于 Web 开发的编程语言,同样具备强大的网络编程能力。接下来,我们将深入探讨 PHP 中网络连接的建立、Socket 编程、…...
【C语言】C语言 食堂自动化管理系统(源码+数据文件)【独一无二】
👉博__主👈:米码收割机 👉技__能👈:C/Python语言 👉专__注👈:专注主流机器人、人工智能等相关领域的开发、测试技术。 【C语言】C语言 食堂自动化管理系统(源…...
mybatis存储过程返回list
在MyBatis中,要想通过调用存储过程返回一个List集合,你需要在Mapper接口中定义一个方法,并使用Param注解来传递存储过程的参数。同时,你需要在Mapper XML文件中配置相应的<select>标签,并指定statementType"…...
【vue】nodejs版本管理利器:nvm
nvm(Node Version Manager)即 Node 版本管理器,是一个用于在系统中轻松安装、管理和切换不同版本 Node.js 的工具。 在实际开发中,不同的项目可能基于不同版本的 Node.js 构建。比如一个旧项目依赖于 Node.js 12.x 版本的特定功能…...
负载测试工具有哪些?
Apache JMeter Apache JMeter 是一款开源的性能测试工具,主要用于对 Web 应用程序进行功能、负载和压力测试。JMeter 支持多种协议和技术,包括 HTTP, HTTPS, FTP 和 WebSocket 等。通过模拟大量并发用户访问来评估应用程序的表现1。 jmeter -n -t testp…...
路由基础 | 路由引入实验 | 不同路由引入方式存在的问题
注:本文为 “路由基础 | 路由表 | 路由引入” 相关文章合辑。 未整理去重。 路由基本概念 1—— 路由表信息、路由进表以及转发流程、最长掩码匹配原则 静下心来敲木鱼已于 2023-11-26 14:06:22 修改 什么是路由 路由就是指导报文转发的路径信息,可以…...
网络安全不分家 网络安全不涉及什么
何为网络安全 信息安全是指系统的硬件、软件及其信息受到保护,并持续正常运行和服务。信息安全的实质是保护信息系统和信息资源免受各种威胁、干扰和破坏,即保证信息的安全性。 网络安全是指利用网络技术、管理和控制等措施,保证网络系统和…...
智能编程助手功能革新与价值重塑之:GitHub Copilot
引言: GitHub Copilot 的最新更新为开发者带来了显著变化,其中 Agent Mode 功能尤为引人注目。该模式能够自动识别并修复代码错误、自动生成终端命令,并具备多级任务推理能力,这使得开发者在开发复杂功能时,可大幅减少…...
wordpress企业官网建站的常用功能
WordPress 是一个功能强大的内容管理系统(CMS),广泛用于企业官网的建设。以下是企业官网建站中常用的 WordPress 功能: 1. 页面管理 自定义页面模板:企业官网通常需要多种页面布局,如首页、关于我们、产品展示、联系我们等。Wor…...
讯方·智汇云校华为官方授权培训机构
1.官方授权 讯方智汇云校是华为领先级授权培训机构(华为授权培训合作伙伴(HALP)体系,分为认证、优选、领先三个等级,领先级是HALP最高级),代表着华为对培训合作伙伴在专业能力、师资队伍、合作…...
C语言中的文件
文章目录 文件1. 流1.1 文件缓冲1.2 标准流1.3 文本文件和二进制文件 2. 打开/关闭文件2.1 fopen2.2 fclose 3. 读写文件3.1 fgetc & fputc3.2 fgets & futs3.3 fscanf & fprintf3.4 fread & fwrite 4. 文件定位5. 错误处理5.1 errno 文件 1. 流 在 C 语言中…...
利用分治策略优化快速排序
1. 基本思想 分治快速排序(Quick Sort)是一种基于分治法的排序算法,采用递归的方式将一个数组分割成小的子数组,并通过交换元素来使得每个子数组元素按照特定顺序排列,最终将整个数组排序。 快速排序的基本步骤&#…...
前端工程化的具体实现细节
🤍 前端开发工程师、技术日更博主、已过CET6 🍨 阿珊和她的猫_CSDN博客专家、23年度博客之星前端领域TOP1 🕠 牛客高级专题作者、打造专栏《前端面试必备》 、《2024面试高频手撕题》 🍚 蓝桥云课签约作者、上架课程《Vue.js 和 E…...
数据分析--数据清洗
一、数据清洗的重要性:数据质量决定分析成败 1.1 真实案例警示 电商平台事故:2019年某电商大促期间,因价格数据未清洗导致错误标价,产生3000万元损失医疗数据分析:未清洗的异常血压值(如300mmHgÿ…...
✨1.HTML、CSS 和 JavaScript 是什么?
✨✨ HTML、CSS 和 JavaScript 是构建网页的三大核心技术,它们相互协作,让网页呈现出丰富的内容、精美的样式和交互功能。以下为你详细介绍: 🦋1. HTML(超文本标记语言) 定义:HTML 是一种用于描…...
从零到上架:用Fyne v2.3.5给你的Go项目加个酷炫的图形界面(Mac/Linux/Windows全平台指南)
从零到上架:用Fyne v2.3.5给你的Go项目加个酷炫的图形界面(Mac/Linux/Windows全平台指南) 如果你已经掌握了Go语言的基础,但厌倦了命令行工具的单调输出,或者想为你的后台服务添加一个用户友好的交互界面,…...
Pixel Epic智识终端参数详解:‘逻辑发散概率’对研报创新性影响分析
Pixel Epic智识终端参数详解:逻辑发散概率对研报创新性影响分析 1. 产品概述与核心价值 Pixel Epic智识终端是一款革命性的研究报告辅助工具,它将枯燥的科研过程转化为一场充满探索乐趣的像素RPG冒险。基于AgentCPM-Report大模型构建,这款工…...
实测对比:Faster-LIO vs FastLIO2,iVox到底让我的Livox Mid360快了多少?
Faster-LIO与FastLIO2性能实测:iVox如何提升Livox Mid360的SLAM效率 当Livox Mid360固态激光雷达以每秒240,000点的速度扫描环境时,传统基于ikd-tree的SLAM算法常面临计算瓶颈。去年我们团队在无人机巡检项目中就遭遇过这样的困境——FastLIO2在复杂植被…...
终极指南:5分钟掌握KMS智能激活工具,永久告别Windows和Office激活烦恼
终极指南:5分钟掌握KMS智能激活工具,永久告别Windows和Office激活烦恼 【免费下载链接】KMS_VL_ALL_AIO Smart Activation Script 项目地址: https://gitcode.com/gh_mirrors/km/KMS_VL_ALL_AIO 你是否曾因Windows系统频繁弹出激活提醒而分心工作…...
Java 25虚拟线程资源调度黄金参数表(2024 Q3压测实录:TPS提升3.8倍,P99延迟下降67ms)
更多请点击: https://intelliparadigm.com 第一章:Java 25虚拟线程资源调度优化全景概览 Java 25 正式将虚拟线程(Virtual Threads)从预览特性转为标准特性,并深度重构了ForkJoinPool与ThreadScheduler协同机制&#…...
5分钟搭建家庭电视直播系统:Kodi IPTV Simple完全指南
5分钟搭建家庭电视直播系统:Kodi IPTV Simple完全指南 【免费下载链接】pvr.iptvsimple IPTV Simple client for Kodi PVR 项目地址: https://gitcode.com/gh_mirrors/pv/pvr.iptvsimple 还在为电视直播体验烦恼吗?想用最简单的方式把网络直播源整…...
打包 Android beeware briefcase
#安装 Android SDK,然后执行: briefcase create android briefcase build android *briefcase run android #连接安卓手机或模拟器运行 briefcase package android #打包为.APK...
php怎么调用字节跳动AI商品推荐_php如何基于用户行为生成千人千面
抖音电商推荐接口需用PHP调用,先在开放平台创建应用获取client_key/client_secret,通过HMAC-SHA256对排序后query参数签名,携带access_token(Redis缓存续期),传合规行为数据调用/item/recommend。怎么用 PH…...
终极指南:iView模态框与下拉菜单的完美焦点控制技巧
终极指南:iView模态框与下拉菜单的完美焦点控制技巧 【免费下载链接】iview A high quality UI Toolkit built on Vue.js 2.0 项目地址: https://gitcode.com/gh_mirrors/iv/iview iView是一个基于Vue.js 2.0构建的高质量UI工具包,提供了丰富的组…...
RimWorld模组管理终极指南:跨平台智能管理器完整教程
RimWorld模组管理终极指南:跨平台智能管理器完整教程 【免费下载链接】RimSort RimSort is an open source mod manager for the video game RimWorld. There is support for Linux, Mac, and Windows, built from the ground up to be a reliable, community-manag…...
