Lambda表达式与匿名内部类的对比详解

Lambda表达式与匿名内部类的对比详解

1. 语法简洁性
  • Lambda表达式
    仅适用于函数式接口(只有一个抽象方法的接口),语法简洁。
    示例

    Runnable r = () -> System.out.println("Hello Lambda");
    
  • 匿名内部类
    适用于任何接口或抽象类,需完整定义类结构。
    示例

    Runnable r = new Runnable() {@Overridepublic void run() {System.out.println("Hello Anonymous Class");}
    };
    

关键差异
Lambda省去了接口名、方法名和new关键字,代码更紧凑。


2. this指向
  • Lambda表达式
    this指向包围Lambda的类实例
    示例

    public class Outer {public void method() {Runnable r = () -> System.out.println(this); // 输出Outer实例}
    }
    
  • 匿名内部类
    this指向匿名内部类自身的实例
    示例

    public class Outer {public void method() {Runnable r = new Runnable() {@Overridepublic void run() {System.out.println(this); // 输出匿名内部类实例}};}
    }
    

3. 编译与性能
  • Lambda表达式

    • 编译时生成invokedynamic指令,运行时动态生成实现类。编译之后,没有生成一个单独的.class字节码文件。
    • 性能优化:JVM缓存Lambda实例,避免重复创建(如单例模式)。
  • 匿名内部类

    • 编译时生成独立的.class文件(如Outer$1.class)。
    • 性能开销:每次实例化均创建新对象。

验证方法
运行后检查项目目录下的target/classesout/production文件夹,观察生成的类文件。


4. 变量捕获
  • 共同规则
    只能访问final或**等效final(effectively final)**的局部变量。

  • Lambda表达式
    捕获的变量在Lambda内部隐式视为final,修改会编译报错。
    示例

    int count = 0;
    Runnable r = () -> count++; // 错误:count必须为final或等效final
    
  • 匿名内部类
    规则相同,但错误提示更明确。
    示例

    int count = 0;
    Runnable r = new Runnable() {@Overridepublic void run() {count++; // 错误:从内部类引用的局部变量必须是final或等效final}
    };
    

5. 应用场景
  • 优先使用Lambda的场景

    1. 实现函数式接口(如RunnableComparator),Lambda表达式,只能是接口。
    2. 需要简洁的代码(如Stream API、事件处理器)。
    3. 性能敏感的重复实例创建场景。
  • 必须使用匿名内部类的场景

    1. 实现非函数式接口(含多个抽象方法)。
    2. 需要覆盖接口的默认方法访问protected方法
    3. 需要继承具体类抽象类

示例对比

// Lambda:仅适用于单方法接口
Function<String, Integer> lengthFunc = s -> s.length();// 匿名内部类:可覆盖默认方法
List<String> list = new ArrayList<>() {@Overridepublic boolean add(String s) {System.out.println("添加元素: " + s);return super.add(s);}
};

6. 内存与类加载
  • Lambda表达式

    • 无额外类文件,减少PermGen/Metaspace内存占用。
    • JVM内部通过LambdaMetafactory动态生成实现。
  • 匿名内部类

    • 每个类生成独立的.class文件,增加元空间负担。
    • 类加载器需加载更多类,影响启动速度。

7. 总结对比表
特性Lambda表达式匿名内部类
适用接口仅函数式接口任意接口或抽象类
语法简洁性
this指向外部类实例内部类自身实例
类文件生成无独立类文件生成Outer$1.class文件
性能开销低(实例可缓存)较高(每次实例化新对象)
变量捕获等效final等效final
覆盖方法不支持支持(可覆盖默认方法)

何时选择Lambda或匿名内部类?

  • 选择Lambda

    • 实现函数式接口且无需覆盖默认方法。
    • 追求代码简洁性和性能优化。
    • 示例:Thread启动、集合排序、Stream操作。
  • 选择匿名内部类

    • 需实现多方法接口或抽象类。
    • 需覆盖接口的默认方法或调用父类protected方法。
    • 示例:自定义List实现、GUI事件监听器(如Swing中的ActionListener)。

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.pswp.cn/diannao/84259.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

Seata Server 1.6.1 高可用部署终极指南:Nacos配置中心+DB存储+多实例实战

文章目录 高可用 - 关键因素存储模式配置中心注册中心高可用 - 步骤第 1 步:使用 db 作为存储模式第 2 步:使用 Nacos 配置中心自定义 seata-server 配置添加 seata-server.properties 到 Nacos第 3 步:修改 application.yml使用 Nacos 作为配置中心使用 Nacos 作为注册中心…

JS 中判断 null、undefined 与 NaN 的权威方法及场景实践

在 JavaScript 中&#xff0c;null、undefined 和 NaN 是三个特殊的「非正常值」&#xff0c;正确判断它们是保证代码健壮性的关键。本文结合 ECMA 规范与 MDN 权威文档&#xff0c;系统梳理三者的判断方法、原理及典型场景&#xff0c;帮助开发者规避常见误区。 一、理解三个…

基于DenseNet的医学影像辅助诊断系统开发教程

本文源码地址: https://download.csdn.net/download/shangjg03/90873921 1. 简介 本教程将使用DenseNet开发一个完整的医学影像辅助诊断系统,专注于胸部X光片的肺炎检测。我们将从环境搭建开始,逐步介绍数据处理、模型构建、训练、评估以及最终的系统部署。 2. 环境准备<…

ubuntu ollama /Dify/Docker部署大模型

电脑需要显卡&#xff1a; 执行下载并安装&#xff1a; curl -fsSL https://ollama.com/install.sh | sh 安装完后到Ollama Search 中查看ollama 可以部署的模型有哪些&#xff1a; 我选择gemma3,所以执行&#xff1a; ollma pull gemma3:latest 这样就把gemma3:latest 模…

课程发布与学习流程全解析

流程 课程发布Controller 获取课程发布信息 ApiOperation("获取课程发布信息") ResponseBody GetMapping("/course/whole/{courseId}") public CoursePreviewDto getPreviewInfo(PathVariable("courseId") Long courseId) {CoursePreviewDto c…

Linux的读写屏障

在 Linux 中&#xff0c;读写屏障&#xff08;Read-Write Barriers&#xff0c;简称 RWB&#xff09;是对内存访问顺序的一种控制机制&#xff0c;用来保证在多核处理器环境下&#xff0c;内存访问的正确顺序&#xff0c;避免因乱序执行导致的数据一致性问题。它是操作系统内核…

Spring AI 和 Elasticsearch 作为你的向量数据库

作者&#xff1a;来自 Elastic Josh Long, Philipp Krenn 及 Laura Trotta 使用 Spring AI 和 Elasticsearch 构建一个完整的 AI 应用程序。 Elasticsearch 原生集成了业界领先的生成式 AI 工具和服务提供商。查看我们关于超越 RAG 基础或使用 Elastic 向量数据库构建生产级应用…

TDengine 高可用——双活方案

概述 部分用户因为部署环境的特殊性只能部署两台服务器&#xff0c;同时希望实现一定的服务高可用和数据高可靠。本文主要描述基于数据复制和客户端 Failover 两项关键技术的 TDengine 双活系统的产品行为&#xff0c;包括双活系统的架构、配置、运维等。TDengine 双活既可以用…

与 JetBrains 官方沟通记录(PyCharm 相关问题反馈)

#工作记录 沟通记录&#xff1a; Subject: Feedback on Terminal and Environment Activation Issues in PyCharm : PY-81233 沟通进度&#xff1a; 【笔记】记一次PyCharm的问题反馈_the polyglot context is using an implementation th-CSDN博客 【笔记】与PyCharm官方沟通…

前端实战:用 JavaScript 模拟文件选择器,同步实现图片预览与 Base64 转换

代码 function 仙盟插件_通用_图片_上传(人间通道id,检验关卡img,仙界指引id){const 人间通道 document.getElementById(人间通道id);const 检验关卡 document.getElementById(检验关卡img);const 仙界指引 document.getElementById(仙界指引id);人间通道.addEventListener(…

数据库设计文档撰写攻略

数据库设计文档撰写攻略 一、数据库设计文档的核心价值二、数据库设计文档的核心框架与内容详解2.1 文档基础信息2.2 需求分析与设计原则2.2.1 业务需求概述2.2.2 设计原则 2.3 数据模型设计2.3.1 概念模型&#xff08;ER 图&#xff09;2.3.2 逻辑模型&#xff08;表结构设计&…

3D个人简历网站 7.联系我

3D个人简历网站 7.联系我 修改Contact.jsx // 从 react 库导入 useRef 和 useState hooks import { useRef, useState } from "react";/*** Contact 组件&#xff0c;用于展示联系表单&#xff0c;处理用户表单输入和提交。* returns {JSX.Element} 包含联系表单的 …

AI大模型从0到1记录学习numpy pandas day25

第 3 章 Pandas 3.1 什么是Pandas Pandas 是一个开源的数据分析和数据处理库&#xff0c;它是基于 Python 编程语言的。 Pandas 提供了易于使用的数据结构和数据分析工具&#xff0c;特别适用于处理结构化数据&#xff0c;如表格型数据&#xff08;类似于Excel表格&#xff09;…

一些可以优化JavaScript性能的工具或库汇总

在 JavaScript 性能优化方面,有许多实用的工具和库可以帮助你分析、监控和提升代码性能。以下是一些常用的工具和库分类整理: 一、性能分析工具 这些工具用于诊断性能瓶颈,定位问题代码。 Chrome DevTools Performance 面板:分析运行时性能,记录函数执行时间、内存使用、…

Linux | tmux | 无法复制粘贴

问题&#xff1a;在Linux中使用tmux时&#xff0c;总是没法使用复制粘贴功能&#xff1b; 解决: 如果希望直接用鼠标选择并复制&#xff08;类似普通终端&#xff09;&#xff0c;可以&#xff1a; 在 ~/.tmux.conf 中添加&#xff1a;sh set -g mouse on;重新加载 tmux 配置…

行贿罪案件(公安侦查阶段)询问笔录发问提纲

一、基本情况核实 与行贿对象&#xff08;受贿人&#xff09;的关系&#xff1f;何时通过何种方式认识&#xff1f;日常交往频率及主要内容&#xff1f; 是否具备国家工作人员身份或其他特定主体资格&#xff1f;是否属于被追诉单位的直接责任人员&#xff1f; 二、行贿动机与…

活到老学到老-Spring参数校验注解Validated /Valid

通过 Validated 和 Valid可以对请求的进行参数校验。 1.核心对比&#xff1a; 特性Valid (JSR-303)Validated (Spring)来源Java标准规范Spring框架扩展分组校验不支持支持&#xff08;通过groups属性&#xff09;嵌套路径自动处理级联校验需配合Valid生效应用范围方法参数、属…

【笔记】JetBrains 数据迁移与符号链接操作

数据迁移与符号链接操作 一、备份原始数据 使用 robocopy 命令备份 C 盘中的源文件夹&#xff0c;确保原始数据完整备份。 robocopy "C:\Users\love\AppData\Local\JetBrains" "E:\Downloads\Other\JetBrains" /E确保备份路径足够存储空间。 二、复制文…

使用 Terraform 创建 Azure Databricks 工作区

使用 Terraform 创建 Azure Databricks Terraform 是一种基础设施即代码(IaC)工具,允许用户通过声明式配置文件来管理和部署云资源。Azure Databricks 是一个基于 Apache Spark 的分析平台,专为数据工程和数据科学设计。通过 Terraform,可以自动化 Azure Databricks 的创…

【zookeeper】--部署3.6.3

文章目录 下载解压创建data和logs配置文件1)创建目录并且编辑 zoo.cfg2)接下来将 node01 的 ZooKeeper 所有文件拷贝至 node02 和 node03。推荐从 node02 和 node03 拷贝4&#xff09;最后 vim /etc/profile 配置环境变量&#xff0c;环境搭建结束。配完环境变量后 source /etc…