java中重写、覆盖,重载三者的区别?

本文详细解析了Java中方法重写与重载的概念及其区别,并通过实例演示了这两种多态性的应用。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >



java中重写、覆盖,重载三者的区别?

 首先要明确Java中重写,覆盖,重载都是针对方法的几个不同概念。其中重写与覆盖等同,只是两种不同的称法而已。
 现在主要来理解下重写与重载的区别?
 以前的理解是:
 重写就是保证跟父类原有方法的返回值,方法名,参数列表一致的前提下,在子类中将函数重新实现一遍。
 而重载就是指返回值和方法名相同,参数列表不同的函数的实现。
 现在细化下理解:
 方法重写(Overriding),是继承与实现中的一个概念,主要指抽象方法的重写。
 方法重载(Overloading)
 两者都是Java中多态性一个的一个体现,方法重写是父类与子类之间多态性的体现,而方法重载主要是类内部多态性的一个体现。
 看如下例子:
 例1:
 
class FatherCat
{
    void eat(){};//method_1
}
 
class Cat extends FatherCat
{
    void eat(){};//method_2
    void eat(String fish){}; //method_3
}
 
例2:

abstract class Animal
{
    abstract void eat();//method_1
}
 
class Cat extends Animal
{
    void eat(){};//method_2
    void eat(String fish){};//method_3
}
 
例3:

interface  Animal
{
    abstract void eat();//method_1
}
 
class Cat implements Animal
{
    public void eat(){};//method_2
    void eat(String fish){};//method_3
}
 
例3注:eat()方法前必须加public权限,因为接口中抽象方法访声明时默认的访问权限都为public,因此子类中实现时,必须重写抽象方法,且访问权限也必须为public.

三个方法之间的关系如下:
method_1与method_2:
 重写关系,子类Cat重写父类FatherCat的eat()方法。
method_2与method_3:
 重载关系,再加一个参数列表不同方法名相同的方法。
method_1与method_3:
 本来没什么关系,若硬是要扯上关系可看成重载关系(个人理解)。

具体区别有人罗列为:

 重写(override)又名覆盖:
1.不能存在同一个类中,在继承或实现关系的类中;
2. 名相同,参数列表相同,方法返回值相同,
3.子类方法的访问修饰符要大于父类的。
4.子类的检查异常类型要小于父类的检查异常。
 重载(overload)
1.可以在一个类中也可以在继承关系的类中;
2.名相同;
3.参数列表不同(个数,顺序,类型) 和方法的返回值类型无关。


简化为:
 重写就是再写一遍,重载就是再加一个。 

### Java 中方法重载重写以及变量隐藏的概念及用法 #### 方法重载(Method Overloading) 方法重载是指在一个类中可以存在多个具有相同名称但参数列表不同的方法。这些差异可以通过参数的数量、类型或者顺序来体现。方法重载允许开发者在同一作用域下定义功能相似但行为略有不同的方法。 例如,在 `Main` 类中,`p()` 方法通过接受不同类型和数量的参数实现了重载[^1]: ```java class A { public void p(int i) { System.out.println("Integer: " + i); } public void p(double d) { System.out.println("Double: " + d); } } ``` 上述代码展示了两个 `p()` 方法分别处理整型和浮点型数据的情况。 #### 方法重写(Method Overriding) 方法重写指的是子类提供了一个与父类中某个已有方法完全一致的方法签名(包括返回值类型、方法名和参数列表)。在这种情况下,当对象实例化为子类时,会优先调用子类中的版本而非父类中的原始版本。为了实现这一特性,通常需要遵循“声明不变,内容重写”的原则[^2]。 下面的例子说明了如何在继承关系里完成方法覆盖操作: ```java class Parent { public void display() { System.out.println("Parent Method"); } } class Child extends Parent { @Override public void display() { super.display(); // 调用了父类里的display() System.out.println("Child Method"); } } ``` 这里需要注意的是,即使子类已经覆写了某些来自父级的功能模块,仍然能够借助关键字 `super` 来访问那些被替代掉的部分[^5]。 #### 变量隐藏(Variable Hiding) 除了方法之外,Java 还支持字段(属性/成员变量)级别的隐藏机制。这意味着如果子类定义了自己的局部变量,并且它的名字恰好跟它所派生出来的那个超类别下的某个非私有的成员变量相匹配的话,则后者会被前者遮蔽住——也就是说此时再尝试去读取这个共享的名字对应的实体将会指向最近的那个范围内的定义项而不是更远端可能存在的另一个同名条目。 举个例子来说就是这样的情况: ```java class SuperClass { protected int value = 10; } class SubClass extends SuperClass{ private int value = 20; public void showValues(){ System.out.println(this.value); // 输出子类中的value -> 20 System.out.println(super.value); // 输出父类中的value -> 10 } } ``` 在这个片段当中可以看出尽管两者都命名为"value",但由于它们分属不同层次结构之中所以彼此之间互不影响同时也各自独立存在着各自的数值表现形式[^4]. --- ### 总结区别与联系 - **方法重载**关注于同一类内部的不同方法变体创建;主要依据参数配置上的变化来进行区分。 - **方法重写**则涉及跨代际间对于特定动作执行方式更新调整的过程;强调保持接口一致性的同时赋予新的具体逻辑实现能力。 - **变量隐藏**则是关于父子两层架构之下可能出现的数据命名冲突解决方案之一种;虽然表面上看起来像是修改原有项目但实际上只是新增加了一版更加贴近当前上下文环境需求的新诠释而已。 这三个概念共同构成了面向对象编程范式下灵活运用资源的重要组成部分。
评论 2
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值