0

0

在Java里类的继承与组合有什么区别_Java面向对象设计解析

P粉602998670

P粉602998670

发布时间:2026-02-06 13:11:03

|

205人浏览过

|

来源于php中文网

原创

继承表示“是一个”(is-a)关系,子类获得父类非私有成员并遵守里氏替换原则;组合表示“有一个”(has-a)关系,通过字段复用行为,更灵活、低耦合、易测试。

在java里类的继承与组合有什么区别_java面向对象设计解析

继承关系在Java里意味着什么

继承表示“是一个”(is-a)关系,子类天然获得父类的非私有成员,同时承担父类的契约责任。Java中用 extends 实现单继承,且子类必须满足里氏替换原则——任何父类能出现的地方,子类也必须能安全替代。

常见错误是把“能用”当成“该用”:比如为复用几个方法就让 Car 继承 Engine,这违反常识(汽车不是引擎),运行时可能触发 ClassCastException 或逻辑错位。

  • 父类 protected 成员可被子类直接访问,但包外不可见
  • final 类不能被继承,final 方法不能被重写
  • 构造器不继承,但子类构造器默认隐式调用 super(),若父类无无参构造器,必须显式写 super(...)

组合关系更贴近真实建模

组合表达“有一个”(has-a)关系,通过在类中声明其他类的实例变量来复用行为。它不产生强耦合,也不要求语义上存在类型兼容性。

例如 Order 类持有 PaymentProcessor 引用,而不是继承它——支付方式可以随时切换(微信支付宝、MockProcessor),而继承会把实现细节锁死在类型系统里。

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

开拍
开拍

用AI制作口播视频

下载
  • 组合对象生命周期通常由宿主类控制,但也可交由外部管理(如依赖注入)
  • 没有语言级语法糖,靠字段 + 构造器/Setter + 委托方法实现
  • 支持运行时替换,天然适配策略模式、装饰器等设计模式

为什么编译期检查过不了,但组合能绕开

继承强制编译器验证类型兼容性,一旦父类签名变更(如加了 abstract 方法),所有子类必须响应;而组合只依赖接口或具体类型的公开API,只要方法存在且签名匹配,就不报错。

典型陷阱是误用继承模拟状态机:比如用 RunningStatePausedState 继承 GameState,结果发现状态切换需要频繁强制转型,且无法共享状态数据。改用组合后,Game 持有 GameState 接口引用,切换只需赋值新实例。

  • 继承导致子类暴露父类实现细节,破坏封装(如父类字段被子类意外修改)
  • 组合可配合 private 字段 + 公共委托方法,隐藏内部对象的创建和使用逻辑
  • 单元测试时,组合对象容易被 Mock,继承链越深,Mock 越难写

选继承还是组合?看这三个信号

真正决定因素不是“能不能”,而是“该不该”。当出现以下任一情况,优先选组合:

  • 想复用代码,但两个类之间不存在自然的 is-a 关系(如 LoggerUserService
  • 需要在运行时动态改变行为(如不同环境加载不同配置解析器)
  • 父类不是为继承设计的——比如没把方法设为 protected,也没标注 @Override 可重写点,甚至用了大量 final 修饰

继承不是坏设计,但它比组合更重、更刚性。一个常被忽略的细节是:Java 的 Object 已经是所有类的隐式父类,你不需要再靠继承去“获得通用能力”,缺功能就加字段、加方法、加接口实现。

热门AI工具

更多
DeepSeek
DeepSeek

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

豆包大模型
豆包大模型

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

通义千问
通义千问

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

腾讯元宝
腾讯元宝

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

文心一言
文心一言

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

讯飞写作
讯飞写作

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

即梦AI
即梦AI

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

ChatGPT
ChatGPT

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

相关专题

更多
go语言 面向对象
go语言 面向对象

本专题整合了go语言面向对象相关内容,阅读专题下面的文章了解更多详细内容。

56

2025.09.05

java面向对象
java面向对象

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

56

2025.11.27

硬盘接口类型介绍
硬盘接口类型介绍

硬盘接口类型有IDE、SATA、SCSI、Fibre Channel、USB、eSATA、mSATA、PCIe等等。详细介绍:1、IDE接口是一种并行接口,主要用于连接硬盘和光驱等设备,它主要有两种类型:ATA和ATAPI,IDE接口已经逐渐被SATA接口;2、SATA接口是一种串行接口,相较于IDE接口,它具有更高的传输速度、更低的功耗和更小的体积;3、SCSI接口等等。

1261

2023.10.19

PHP接口编写教程
PHP接口编写教程

本专题整合了PHP接口编写教程,阅读专题下面的文章了解更多详细内容。

275

2025.10.17

php8.4实现接口限流的教程
php8.4实现接口限流的教程

PHP8.4本身不内置限流功能,需借助Redis(令牌桶)或Swoole(漏桶)实现;文件锁因I/O瓶颈、无跨机共享、秒级精度等缺陷不适用高并发场景。本专题为大家提供相关的文章、下载、课程内容,供大家免费下载体验。

2196

2025.12.29

java接口相关教程
java接口相关教程

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

34

2026.01.19

1688阿里巴巴货源平台入口与批发采购指南
1688阿里巴巴货源平台入口与批发采购指南

本专题整理了1688阿里巴巴批发进货平台的最新入口地址与在线采购指南,帮助用户快速找到官方网站入口,了解如何进行批发采购、货源选择以及厂家直销等功能,提升采购效率与平台使用体验。

21

2026.02.06

快手网页版入口与电脑端使用指南 快手官方短视频观看入口
快手网页版入口与电脑端使用指南 快手官方短视频观看入口

本专题汇总了快手网页版的最新入口地址和电脑版使用方法,详细提供快手官网直接访问链接、网页端操作教程,以及如何无需下载安装直接观看短视频的方式,帮助用户轻松浏览和观看快手短视频内容。

0

2026.02.06

C# 多线程与异步编程
C# 多线程与异步编程

本专题深入讲解 C# 中多线程与异步编程的核心概念与实战技巧,包括线程池管理、Task 类的使用、async/await 异步编程模式、并发控制与线程同步、死锁与竞态条件的解决方案。通过实际项目,帮助开发者掌握 如何在 C# 中构建高并发、低延迟的异步系统,提升应用性能和响应速度。

0

2026.02.06

热门下载

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

精品课程

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

共23课时 | 3.3万人学习

C# 教程
C# 教程

共94课时 | 8.7万人学习

Java 教程
Java 教程

共578课时 | 58.6万人学习

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

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