0

0

什么是Java中的方法隐藏 (Hiding)_静态方法与实例方法重写的差异

P粉602998670

P粉602998670

发布时间:2026-02-18 13:09:15

|

827人浏览过

|

来源于php中文网

原创

静态方法不能被重写,只能被隐藏;调用取决于编译时引用类型而非运行时对象类型,如parent p = new child(); p.staticmethod()执行parent版本。

什么是java中的方法隐藏 (hiding)_静态方法与实例方法重写的差异

静态方法不能被重写,只能被隐藏

Java里没有“静态方法重写”这回事。子类定义一个和父类签名完全相同的static方法时,不是覆盖(override),而是隐藏(hiding)。调用哪个版本,**取决于编译时的引用类型,而不是运行时的实际对象类型**。

常见错误现象:Parent p = new Child(); p.staticMethod(); 调用的是Parent.staticMethod(),不是Child里的——哪怕p实际指向Child实例。

  • 使用场景:多用于工具类继承时提供同名但语义更具体的静态入口,比如StringUtils子类想加个formatForInternalUse(),但不能靠多态自动分发
  • 参数差异:签名必须完全一致(包括返回类型、参数列表、static修饰符),否则就是新方法,不构成隐藏
  • 性能影响:无额外开销,因为绑定在编译期完成;但容易让人误以为是动态绑定,引发逻辑 bug

实例方法重写(Override)和静态方法隐藏(Hiding)的关键区别

核心就一条:重写看对象,隐藏看引用。

示例对比:

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

LOGO.com
LOGO.com

在线生成Logo,100%免费

下载
class A { static void m() { System.out.println("A.m"); } void n() { System.out.println("A.n"); } }
class B extends A { static void m() { System.out.println("B.m"); } void n() { System.out.println("B.n"); } }

A a1 = new B();
a1.m(); // 输出 "A.m" —— 静态方法,按 a1 的声明类型 A 找
a1.n(); // 输出 "B.n" —— 实例方法,按 new B() 的实际类型找
  • 编译期检查:隐藏不要求@Override注解,加了会报错;重写必须可加(且推荐加),否则可能因签名不符而意外变成新方法
  • 访问控制:隐藏方法可以比父类更宽松(如父类protected,子类public),重写则不能更严格
  • 异常声明:隐藏对throws无限制;重写不能抛出父类未声明的受检异常

为什么编译器不阻止你在子类里“重写”静态方法

因为语法上完全合法——静态方法本来就不参与多态,JVM 层面也没有 vtable 查找机制。它只是“恰好同名”,编译器只做符号解析,不做强制约束。

容易踩的坑:

  • 把隐藏当重写用,结果测试时用Child c = new Child(); c.staticMethod();看起来正常,一换成Parent p = new Child(); p.staticMethod();就出错
  • IDE 提示“Method hides a static method in superclass”,很多人直接点“suppress”忽略,埋下隐患
  • 单元测试若只用具体类型调用,根本测不出隐藏导致的逻辑偏差

什么时候该用隐藏,什么时候该重构

隐藏不是设计模式,而是语言限制下的妥协。真需要行为差异化,优先考虑实例方法 + 多态;静态方法适合无状态、与类型无关的操作。

  • 适合隐藏的场景:子类提供同名静态工具方法,但实现细节不同,且调用方明确知道用哪个类名调用(如JsonUtil.parse() vs XmlUtil.parse()
  • 该重构的情况:如果发现总要根据对象类型决定调用哪个静态方法,说明它本该是实例方法——把逻辑移到parse(String)实例方法里,再让子类重写
  • 替代方案:用工厂方法或策略接口,避免在静态层做分支判断

最常被忽略的一点:静态方法隐藏不会触发任何运行时多态机制,所以它和“继承”在语义上其实是割裂的——你写的不是“子类扩展父类行为”,只是“碰巧起了个一样的名字”。这点在代码审查时极难察觉。

热门AI工具

更多
DeepSeek
DeepSeek

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

豆包大模型
豆包大模型

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

通义千问
通义千问

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

腾讯元宝
腾讯元宝

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

文心一言
文心一言

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

讯飞写作
讯飞写作

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

即梦AI
即梦AI

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

ChatGPT
ChatGPT

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

相关专题

更多
string转int
string转int

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

770

2023.08.02

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

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

22

2025.11.27

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

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

22

2025.11.27

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

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

22

2025.11.27

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

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

1508

2023.10.19

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

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

423

2025.10.17

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

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

2260

2025.12.29

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

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

37

2026.01.19

pixiv网页版官网登录与阅读指南_pixiv官网直达入口与在线访问方法
pixiv网页版官网登录与阅读指南_pixiv官网直达入口与在线访问方法

本专题系统整理pixiv网页版官网入口及登录访问方式,涵盖官网登录页面直达路径、在线阅读入口及快速进入方法说明,帮助用户高效找到pixiv官方网站,实现便捷、安全的网页端浏览与账号登录体验。

561

2026.02.13

热门下载

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

精品课程

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

共23课时 | 3.7万人学习

C# 教程
C# 教程

共94课时 | 9.7万人学习

Java 教程
Java 教程

共578课时 | 67.7万人学习

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

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