重载、覆盖(重写)、隐藏

重载(overload)

函数重载是指在一个类中声明多个名称相同但参数列表不同的函数,这些参数可能个数不同,也可能顺序不同,也可能类型不同,但是不能依靠函数的返回值类型来判断函数是否重载。函数重载的特征有:

(1)相同的范围,即在同一个作用域中

(2)函数名字相同

(3)函数参数不同

(4)virtual关键字可有可无

(5)返回值可以不同,也可以相同

覆盖(override)

函数覆盖又称函数重写,是指子类重新定义基类的函数。特征是:

(1)不在同一个作用域,分别位于子类与父类中

(2)函数名字相同

(3)函数参数相同

(4)基类函数必须是virtual函数,不能有static

(5)函数返回值相同

(6)重写函数的访问修饰符可以不同

隐藏

函数隐藏又称函数重定义。特征有:

(1)不在同一个作用域,分别位于子类和基类中

(2)函数名字相同

(3)函数返回值可以不相同

(4)函数参数不同。此时,不论是否有virtual关键字,基类的函数将被隐藏

(5)函数参数相同,但是基类函数没有virtual关键字。此时,基类的函数被隐藏

重写与重载的区别

方法的重写与重载都是实现多态的方式,区别在于重载实现的是编译时的多态性,重写实现的是运行时的多态性。

重载发生在同一个类中,同名的方法如果有不同的参数列表(参数类型不同、参数个数不同或者两者都不同)则视为重载;重写发生在子类与父类之间,重写要求子类重写的方法与父类被重写的方法具有相同的返回类型,但要比父类被重写的方法更容易被访问,同时不能比父类被重写的方法声明更多的异常。

重载的规则:方法名一致,参数列表中参数的顺序、类型、数量不相同;重载的两个方法大的返回值不需要一致;可以抛出不同的异常,可以有不同的修饰符

重写的规则:重写方法的参数列表必须与被重写方法的参数列表保持完全一致,返回值类型也必须保持一致;构造方法不能被重写,声明为 final 的方法不能被重写,声明为 static 的方法不能被重写;子类中重写方法的访问权限不能比父类中被重写方法的访问权限低;重写的方法能够抛出任何非强制异常(非运行时异常),无论被重写的方法是否抛出异常

英文位置修饰符返回值方法名参数抛出异常方法体
重载overload同一个类中无关无关必须相同必须不同无关不同
重写override父类子类中父类小于等于子类父类大于等于子类必须相同必须相同子类小于等于父类不同

### 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、付费专栏及课程。

余额充值