java基础——重写、隐藏、重载

本文深入解析Java中的方法重写与重载概念,包括它们的定义、规则及应用示例。同时,对比了重写与隐藏的区别,帮助读者理解如何在面向对象编程中正确使用这些特性。

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

方法签名:方法名+参数列表(参数类型、个数、顺序)

重写:

子类重写父类方法,仅限于实例方法。成员变量和静态方法不能被重写,只能被隐藏。

重写原则:

1.方法名相同,参数类型相同。

2.子类返回类型小于等于父类返回类型。

3.子类异常小于等于父类异常。

4.子类访问权限大于等于父类访问权限。

重写方法可以改变其他方法修饰符如final,synchronize,native等。不管被重写方法中有无final修饰的参数,重写方法都可以增加、保留、取出这个参数的final修饰符,即参数修饰符不属于方法签名。

 

重载:

同一个类中,有多个方法名相同,参数列表不同(个数、类型不同),与返回值无关,与权限修饰符无关(https://blog.youkuaiyun.com/weixin_42294335/article/details/80427124,如果只有返回值不同,会提示方法名重复。

java中方法可以与类重名,构造方法没有返回值。

 

隐藏:

形式上与重写类似,但只有成员变量和静态方法可以被隐藏。

 

 

 

3、隐藏和覆盖的区别(https://blog.youkuaiyun.com/snow_7/article/details/51579278

(1)被隐藏的属性,在子类被强制转换成父类后,访问的是父类中的属性

  在无强制转换时子类要访问父类的属性使用super关键字

(2)被覆盖的方法,在子类被强制转换成父类后,调用的还是子类自身的方法

     子类要是想访问父类的方法,可以使用super关键字
 

public class Test {
    public static void main(String[] args)  {
    	Circle circle = new Circle();//本类引用指向本类对象
        Shape shape = new Circle();//父类引用指向子类对象(会有隐藏和覆盖)
        
       System.out.println(circle.name);
       circle.printType();
       circle.printName();
       //以上都是调用Circle类的方法和引用
       
        System.out.println(shape.name);//调用父类被隐藏的name属性
        shape.printType();//调用子类printType的方法
        shape.printName();//调用父类隐藏的printName方法 
    }
}
 
class Shape {
    public String name = "shape";
     
    public Shape(){
        System.out.println("shape constructor");
    }
     
    public void printType() {
        System.out.println("this is shape");
    }
     
    public static void printName() {
        System.out.println("shape");
    }
}
 
class Circle extends Shape {
    public String name = "circle"; //父类属性被隐藏
     
    public Circle() {
        System.out.println("circle constructor");
    }
   
    //对父类实例方法的覆盖
    public void printType() {
        System.out.println("this is circle");
    }
    
   //对父类静态方法的隐藏  
    public static void printName() {
        System.out.println("circle");
    }
}
//运行结果:
shape constructor
circle constructor
 
circle
this is circle
circle
 
shape
this is circle
shape

 

可以看到转到父类对象后,重写的调用的是自己的静态方法或成员变量,隐藏的调用的是父类的静态方法或成员变量。

 

 

参考:

1. https://github.com/kdn251/interviews

2. https://blog.youkuaiyun.com/snow_7/article/details/51579278

3.https://blog.youkuaiyun.com/weixin_42294335/article/details/80427124

### 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]. --- ### 总结区别与联系 - **方法重载**关注于同一类内部的不同方法变体创建;主要依据参数配置上的变化来进行区分。 - **方法重写**则涉及跨代际间对于特定动作执行方式更新调整的过程;强调保持接口一致性的同时赋予新的具体逻辑实现能力。 - **变量隐藏**则是关于父子两层架构之下可能出现的数据命名冲突解决方案之一种;虽然表面上看起来像是修改原有项目但实际上只是新增加了一版更加贴近当前上下文环境需求的新诠释而已。 这三个概念共同构成了面向对象编程范式下灵活运用资源的重要组成部分。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值