0

0

在Java里抽象类和接口的设计场景_Java抽象类与接口选择指南

P粉602998670

P粉602998670

发布时间:2026-02-11 13:40:47

|

177人浏览过

|

来源于php中文网

原创

抽象类适合共享状态和部分实现,接口适合定义能力契约;必须用抽象类时包括复用字段、构造逻辑或非公开方法;Java 8 的 default 方法用于接口演进兼容,不可替代抽象类。

在java里抽象类和接口的设计场景_java抽象类与接口选择指南

抽象类和接口不是“选哪个更好”,而是“哪个更贴合当前的建模意图”——如果需要共享状态或部分实现,用抽象类;如果定义能力契约、支持多继承语义,用接口。

什么时候必须用抽象类

当你需要在多个子类间复用字段、构造逻辑或非公开方法时,抽象类是唯一选择。接口不能有实例字段(static final 除外),也不能有 protected 方法或带实现的构造器。

  • 子类共用一个 id 字段和自增逻辑?抽象类里声明 protected long id + protected static AtomicLong counter
  • 所有子类初始化前都需校验配置?在抽象类构造器里调用 validateConfig(),子类通过 super(...) 触发
  • 想提供默认日志行为但允许子类覆盖?写一个 protected void log(String msg),子类可重写或直接用

强行用接口模拟这些,只能靠静态工具类 + 每个实现类重复写字段,既破坏封装,又丧失继承链上的统一管控。

为什么从 Java 8 开始接口也能有 default 方法,但不该滥用

default 方法本质是“契约的可选实现”,不是“可复用的基类逻辑”。它解决的是接口演进时的兼容性问题,不是替代抽象类的设计角色。

立即学习Java免费学习笔记(深入)”;

SolidPoint
SolidPoint

Youtube视频总结器,快速将Youtube长视频压缩成文字摘要

下载
  • 你在接口里加了 default String format() { return toString(); },没问题;但若开始往里塞 private void initCache()protected List buffer,说明你其实在写抽象类
  • 多个接口都有同名 default 方法,实现类又没重写,编译直接报错:class A inherits unrelated defaults for methodX() from types B and C
  • default 方法无法访问实现类的私有字段,也无法调用 this 上的非 public 方法,能力边界比抽象类窄得多

接口更适合描述“能做什么”,抽象类更适合描述“是什么”

这是最实用的判断锚点。比如:

  • RunnableComparableSerializable —— 都是能力标签,不关心实现细节,用接口
  • AbstractListAbstractMapInputStream —— 提供核心骨架(如迭代器、读取缓冲、size 计算),子类只需补关键步骤,用抽象类
  • 一个类既要 Serializable 又要 Comparable 还要 Cloneable?只能靠接口组合;但如果你发现三个子类都在重复写几乎一样的 readObject()writeObject(),那就该抽个 AbstractSerializableEntity

Java 14+ 的 sealed class 不是接口/抽象类的替代品

sealed 类限制谁可以继承它,但它本身仍是具体或抽象的类。它解决的是“类型封闭性”问题,不是“契约抽象”问题。

  • 你想让只有 CircleSquare 能继承 Shape?用 abstract sealed class Shape permits Circle, Square
  • Shape 自身仍得决定是抽象类(提供 area() 抽象方法 + 公共 color 字段)还是接口(只定义 area()perimeter()
  • 别试图用 sealed interface —— Java 不支持,且违背接口本意:接口天生就该被任意实现,封住它等于否定多态的开放性

真正容易被忽略的,是抽象类里 final 方法的使用频率太低——它比 default 更适合表达“骨架不可变,钩子可扩展”的意图,比如模板方法模式里的 execute() 声明为 final,而 before()after() 留给子类。

热门AI工具

更多
DeepSeek
DeepSeek

幻方量化公司旗下的开源大模型平台

豆包大模型
豆包大模型

字节跳动自主研发的一系列大型语言模型

通义千问
通义千问

阿里巴巴推出的全能AI助手

腾讯元宝
腾讯元宝

腾讯混元平台推出的AI助手

文心一言
文心一言

文心一言是百度开发的AI聊天机器人,通过对话可以生成各种形式的内容。

讯飞写作
讯飞写作

基于讯飞星火大模型的AI写作工具,可以快速生成新闻稿件、品宣文案、工作总结、心得体会等各种文文稿

即梦AI
即梦AI

一站式AI创作平台,免费AI图片和视频生成。

ChatGPT
ChatGPT

最最强大的AI聊天机器人程序,ChatGPT不单是聊天机器人,还能进行撰写邮件、视频脚本、文案、翻译、代码等任务。

相关专题

更多
string转int
string转int

在编程中,我们经常会遇到需要将字符串(str)转换为整数(int)的情况。这可能是因为我们需要对字符串进行数值计算,或者需要将用户输入的字符串转换为整数进行处理。php中文网给大家带来了相关的教程以及文章,欢迎大家前来学习阅读。

688

2023.08.02

java多态详细介绍
java多态详细介绍

本专题整合了java多态相关内容,阅读专题下面的文章了解更多详细内容。

20

2025.11.27

java多态详细介绍
java多态详细介绍

本专题整合了java多态相关内容,阅读专题下面的文章了解更多详细内容。

20

2025.11.27

format在python中的用法
format在python中的用法

Python中的format是一种字符串格式化方法,用于将变量或值插入到字符串中的占位符位置。通过format方法,我们可以动态地构建字符串,使其包含不同值。php中文网给大家带来了相关的教程以及文章,欢迎大家前来阅读学习。

864

2023.07.31

python中的format是什么意思
python中的format是什么意思

python中的format是一种字符串格式化方法,用于将变量或值插入到字符串中的占位符位置。通过format方法,我们可以动态地构建字符串,使其包含不同值。本专题为大家提供相关的文章、下载、课程内容,供大家免费下载体验。

442

2024.06.27

javascriptvoid(o)怎么解决
javascriptvoid(o)怎么解决

javascriptvoid(o)的解决办法:1、检查语法错误;2、确保正确的执行环境;3、检查其他代码的冲突;4、使用事件委托;5、使用其他绑定方式;6、检查外部资源等等。本专题为大家提供相关的文章、下载、课程内容,供大家免费下载体验。

180

2023.11.23

java中void的含义
java中void的含义

本专题整合了Java中void的相关内容,阅读专题下面的文章了解更多详细内容。

109

2025.11.27

java多继承如何实现
java多继承如何实现

本专题整合了java多继承相关内容以及教程,阅读专题下面的文章了解更多详细内容。

27

2025.10.28

Rust异步编程与Tokio运行时实战
Rust异步编程与Tokio运行时实战

本专题聚焦 Rust 语言的异步编程模型,深入讲解 async/await 机制与 Tokio 运行时的核心原理。内容包括异步任务调度、Future 执行模型、并发安全、网络 IO 编程以及高并发场景下的性能优化。通过实战示例,帮助开发者使用 Rust 构建高性能、低延迟的后端服务与网络应用。

1

2026.02.11

热门下载

更多
网站特效
/
网站源码
/
网站素材
/
前端模板

精品课程

更多
相关推荐
/
热门推荐
/
最新课程
Kotlin 教程
Kotlin 教程

共23课时 | 3.4万人学习

C# 教程
C# 教程

共94课时 | 9.1万人学习

Java 教程
Java 教程

共578课时 | 62.6万人学习

关于我们 免责申明 举报中心 意见反馈 讲师合作 广告合作 最新更新
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送

Copyright 2014-2026 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号