javajava 重写与重载载的区别和注意事项

Java 重写与重载(区别与用途)_Linux编程_Linux公社-Linux系统门户网站
你好,游客
Java 重写与重载(区别与用途)
来源:Linux社区&
作者:kyyee
对于初学者而言,概念往往很难理清楚。我根据我的理解来谈谈 Java 中重写方法与重载方法的区别。
Java 中重写又叫覆盖,主要是指继承(extends)父类或者实现(implements)接口时将父类或者接口中已经存在的方法进行重新定义。重写的方法在父类或者接口中必须存在。
注意:后文的重写方法与覆盖方法同义
覆盖父类或者接口方法的规则
重写方法的方法名必须与父类或接口方法名相同,否则是定义新方法
重写方法的方法参数必须与父类或接口方法参数相同,否则是重载方法
重写方法的返回类型必须与父类或接口方法返回类型相同,否则是重载方法
重写方法的访问修饰符必须比父类或者接口方法的访问修饰符大(public&protected&default&private),否则运行时可能出现异常
重写方法不能抛出父类中没有的检查型异常
重写方法不能抛出父类抛出异常的父异常
父类或者接口中需要被重写的方法不能被定义为 private,私有方法对子类不可见,在接口中定义私有方法没有意义
静态方法不能被重写为非静态的方法(编译不通过)
重载方法具有相同的方法名,不同的方法参数(参数个数,参数类型),重载在 Java 中很常见。例如 jar 包中的 String 类,它的构造函数就有很多的重载方法。
重载方法的规则
重载方法的方法名必须相同
重载方法的方法参数必须不同,方法参数可以是不同的参数个数,参数类型,参数顺序(参数类型必须不同)
不能通过访问权限,返回类型,抛出的异常类型进行方法重载
注意:通常,我们在重写方法前面加上 @Override ,它表示这是一个重写方法,编译器会自动去父类或者接口中帮我们检查重写方法是否符合相关规则。 注意:对于重载方法,我们在方法前面加上 @Overload ,该注解没有实际含义,仅表示该方法是一个重载方法
重写(覆盖)方法的意义
相信读者朋友都还记得 Java 语言的三大特性:封装,继承,多态,而方法的重写就很好的诠释了 Java 继承性。
重载方法的意义
重载方法使用相同的方法名,需要通过不同的方法参数来区分,这是 Java 多态性的一种体现。
相关资讯 & & &
& (04/21/:02)
   同意评论声明
   发表
尊重网上道德,遵守中华人民共和国的各项有关法律法规
承担一切因您的行为而直接或间接导致的民事或刑事法律责任
本站管理人员有权保留或删除其管辖留言中的任意内容
本站有权在网站内转载或引用您的评论
参与本评论即表明您已经阅读并接受上述条款随笔 - 80&
文章 - 0&评论 - 3&trackbacks - 0
首先我们来讲讲:重载(Overloading)
&&& (1) 方法重载是让类以统一的方式处理不同类型数据的一种手段。多个同名函数同时存在,具有不同的参数个数/类型。
重载Overloading是一个类中多态性的一种表现。
&&& (2)&的方法重载,就是在类中可以创建多个方法,它们具有相同的名字,但具有不同的参数和不同的定义。
调用方法时通过传递给它们的不同参数个数和参数类型来决定具体使用哪个方法, 这就是多态性。
&&& (3) 重载的时候,方法名要一样,但是参数类型和个数不一样,返回值类型可以相同也可以不相同。无法以返回型别作为重载函数的区分标准。
下面是重载的例子:&&& package c04.//这是包名&&& //这是这个程序的第一种编程方法,在main方法中先创建一个Dog类实例,然后在Dog类的构造方法中利用this关键字调用不同的bark方法。
不同的重载方法bark是根据其参数类型的不同而区分的。
&&& //注意:除构造器以外,编译器禁止在其他任何地方中调用构造器。&&& package c04.
&&& public class Dog {&&&&&&&& Dog()&&&&&&&& {&&&&&&&&&&&&&&& this.bark();&&&&&&&& }&&&&&&&& void bark()//bark()方法是重载方法&&&&&&&& {&&&&&&&&&&&&&&& System.out.println(\"no barking!\");&&&&&&&&&&&&&&& this.bark(\"female\", 3.4);&&&&&&&& }&&&&&&&& void bark(String m,double l)//注意:重载的方法的返回值都是一样的,&&&&&&&& {&&&&&&&&&&&&&&& System.out.println(\"a barking dog!\");&&&&&&&&&&&&&&& this.bark(5, \"China\");&&&&&&&& }&&&&&&&& void bark(int a,String n)//不能以返回值区分重载方法,而只能以&参数类型&和&类名&来区分&&&&&&&& {&&&&&&&&&&&&&&& System.out.println(\"a howling dog\");&&&&&&&& }
&&&&&&&& public static void main(String[] args)&&&&&&&& {&&&&&&&&&&&&&&& Dog dog = new Dog();&&&&&&&&&&&&&&& //dog.bark(); [Page]&&&&&&&&&&&&&&& //dog.bark(\"male\", \"yellow\");&&&&&&&&&&&&&&& //dog.bark(5, \"China\");
  然后我们再来谈谈 重写(Overriding)
&&& (1) 父类与子类之间的多态性,对父类的函数进行重新定义。如果在子类中定义某方法与其父类有相同的名称和参数,我们说该方法被重写 (Overriding)。在中,子类可继承父类中的方法,而不需要重新编写相同的方法。
但有时子类并不想原封不动地继承父类的方法,而是想作一定的修改,这就需要采用方法的重写。
方法重写又称方法覆盖。
&&& (2)若子类中的方法与父类中的某一方法具有相同的方法名、返回类型和参数表,则新方法将覆盖原有的方法。
如需父类中原有的方法,可使用super关键字,该关键字引用了当前类的父类。
&&& (3)子类函数的访问修饰权限不能少于父类的; &&& 下面是重写的例子:
&&& 概念:即调用对象方法的机制。
&&& 动态绑定的内幕:
&&& 1、编译器检查对象声明的类型和方法名,从而获取所有候选方法。试着把上例Base类的test注释掉,这时再编译就无法通过。
&&& 2、重载决策:编译器检查方法调用的参数类型,从上述候选方法选出唯一的那一个(其间会有隐含类型转化)。
如果编译器找到多于一个或者没找到,此时编译器就会报错。试着把上例Base类的test(byte b)注释掉,这时运行结果是1 1。
&&& 3、若方法类型为priavte static final ,java采用静态编译,编译器会准确知道该调用哪 &&& 个方法。
&&& 4、当程序运行并且使用动态绑定来调用一个方法时,那么虚拟机必须调用对象的实际类型相匹配的方法版本。
在例子中,b所指向的实际类型是TestOverriding,所以b.test(0)调用子类的test。
但是,子类并没有重写test(byte b),所以b.test((byte)0)调用的是父类的test(byte b)。
如果把父类的(byte b)注释掉,则通过第二步隐含类型转化为int,最终调用的是子类的test(int i)。
学习总结:
& & 多态性是面向对象编程的一种特性,和方法无关, & & 简单说,就是同样的一个方法能够根据输入数据的不同,做出不同的处理,即方法的 &&& 重载&&有不同的参数列表(静态多态性)
 &而当子类继承自父类的相同方法,输入数据一样,但要做出有别于父类的响应时,你就要覆盖父类方法,
& & 即在子类中重写该方法&&相同参数,不同实现(动态多态性)
&OOP三大特性:继承,多态,封装。
&&& public class Base&&& {&&&&&&& void test(int i)&&&&&&& {&&&&&&&&&&& System.out.print(i);&&&&&&& }&&&&&&& void test(byte b)&&&&&&& {&&&&&&&&&&& System.out.print(b);&&&&&&& }&&& }&&& public class TestOverriding extends Base&&& {&&&&&&& void test(int i)&&&&&&& {&&&&&&&&&&& i++;&&&&&&&&&&& System.out.println(i);&&&&&&& }&&&&&&&&& public static void main(String[]agrs)&&&&&&& {&&&&&&&&&&& Base b=new TestOverriding();&&&&&&&&&&& b.test(0)&&&&&&&&&&& b.test((byte)0)&&&&&&& }&&& }
&&& 这时的输出结果是1&&&& 0,这是运行时动态绑定的结果。
重写的主要优点是能够定义某个子类特有的特征:
public&class&Father{
&&&public&void&speak(){
&&&&&&&System.out.println(Father);
public&class&Son&extends&Father{
&&&&public&void&speak(){
&&&&&&&&System.out.println("son");
这也叫做多态性,重写方法只能存在于具有继承关系中,重写方法只能重写父类非私有的方法。
当上例中Father类speak()方法被private时,Son类不能重写出Father类speak()方法,此时Son类speak()方法相当与在Son类中定义的一个speak()方法。
Father类speak()方法一但被final时,无论该方法被public,protected及默认所修饰时,Son类根本不能重写Father类speak()方法,
试图编译代码时,编译器会报错。例:
public&class&Father{
&&&final&public&void&speak(){
&&&&&&&System.out.println("Father");
public&class&Son&extends&Father{
&&&&public&void&speak(){
&&&&&&&System.out.println("son");
}&&&&&&&//编译器会报错;
Father类speak()方法被默认修饰时,只能在同一包中,被其子类被重写,如果不在同一包则不能重写。
Father类speak()方法被protoeted时,不仅在同一包中,被其子类被重写,还可以不同包的子类重写。
重写方法的规则:
1、参数列表必须完全与被重写的方法相同,否则不能称其为重写而是重载。
2、返回的类型必须一直与被重写的方法的返回类型相同,否则不能称其为重写而是重载。
3、访问修饰符的限制一定要大于被重写方法的访问修饰符(public&protected&default&private)
4、重写方法一定不能抛出新的检查异常或者比被重写方法申明更加宽泛的检查型异常。例如:
父类的一个方法申明了一个检查异常IOException,在重写这个方法是就不能抛出Exception,只能抛出IOException的子类异常,可以抛出非检查异常。
而重载的规则:
1、必须具有不同的参数列表;
2、可以有不责骂的返回类型,只要参数列表不同就可以了;
3、可以有不同的访问修饰符;
4、可以抛出不同的异常;
重写与重载的区别在于:
重写多态性起作用,对调用被重载过的方法可以大大减少代码的输入量,同一个方法名只要往里面传递不同的参数就可以拥有不同的功能或返回值。
用好重写和重载可以设计一个结构清晰而简洁的类,可以说重写和重载在编写代码过程中的作用非同一般.
阅读(...) 评论()java 重载与重写方法讲解
初学java的时候容易将两者弄错,对两者的概念不是很清楚,这篇文章主要来讲讲两者的区别。
方法重载(Overload)
方法重载指的是在一个类中可以创建多个方法,方法名字相同,而参数列表不同。
重载规则:
参数列表不同(参数的个数、类型或顺序不同) 不能以返回值类型作为重载函数的区分标准。
方法重写(Override)
重写是子类对父类的允许访问的方法的实现过程重新编写,返回值和形参都不能改变。
重写的好处在于子类可以根据需要定义特定于自己的行为,子类可以根据需要实现父类的方法。
重写规则:
参数列表必须完全和被重写的方法相同。 返回值类型必须相同。 访问权限不能比父类中被重写方法的访问权限更低。(父类的一个方法为public,子类重写该方法就不能声明为protected) 声明为final的方法不能被重写 声明为static的方法不能被重写,但是能够被再次声明。博客分类:
java中重载和重写的区别:
必须就有不同的参数列表;
可以有不同的返回类型;
可以有不同的访问修饰符;
可以抛出不同的异常;
public class Demo{
void speak(){
System.out.println("重载方法");
void speak(int a){
System.out.println(a);
注意:不能以返回类型来区分重载方法,只能以“参数类型”和“类名”来区分。
参数列表必须与被重写的方法的相同;
返回的类型必须与被重写的方法的相同;
访问修饰符的限定必须大于被重写的方法的访问修饰符(public&protected&default&private);
重写方法一定不能抛出新的检查异常或者重写的方法申明更加宽泛的检查异常;
public class Father{
public void speak(){
System.out.println("Father");
public class Son extend Father{
public void speak(){
System.out.println("Son");
浏览: 1359 次
来自: 北京
(window.slotbydup=window.slotbydup || []).push({
id: '4773203',
container: s,
size: '200,200',
display: 'inlay-fix'重写是父类与子类之间多态性的一种表现
重写是一个类中多态性的一种表现
重载是一个类中多态性的一种表现
重载是父类与子类之间多态性的一种表现
重写是子类继承父类方法并对其进行修改,可选择调用父类方法或子类重写后的同名方法
重载是在一个类可以存在同名但参数列表不同的方法,可根据传入的参数调用相应的方法
A C 重写(Overriding)是父类与子类之间多态性的一种表现,类的不同实现可以重写父类方法,实现同方法名,同参数,同返回类型,不同的实现。重载(Overloading)最典型的就是一个类的不同构造函数,方法名相同,参数个数不同,返回类型也可以不同,重载是一个类中多态性的一种表现。
重写是父类和子类,是两个类的;
重载是一个类
成功记反,巧妙的回避了正确答案!
按多态的定义来,多态必须要有继承,重载根本就不能和多态扯上关系,这一点《程序员面试宝典》有过说明--“重载只是一种语言特性,与多态无关,也与面向对象无关”
对于B 重写不是在一个类中的多态表现,重写发生在父子之间。
重写Overriding是父类与子类之间多态性的一种表现,重载Overloading是一个类中多态性的一种表现。如果在子类中定义某方法与其父类有相同的名称和参数,我们说该方法被重写
(Overriding)。子类的对象使用这个方法时,将调用子类中的定义,对它而言,父类中的定义如同被“屏蔽”了。如果在一个类中定义了多个同名的方法,它们或有不同的参数个数或有不同的参数类型,则称为方法的重载(Overloading)。
Overloaded的方法是可以改变返回值的类型。
Java语言中,方法的重写(Overriding)和重载(Overloading)是多态性的不同表现。
重写是父类与子类之间多态性的一种表现。
重载是一个类中多态性的一种表现。
重写是子类继承父类方法并对其进行修改,可选择调用父类方法或子类重写后的同名方法
重载是在一个类可以存在同名但参数列表不同的方法,可根据传入的参数调用相应的方法
是----& 一个类中 &-----多态性的一种表现
重写是继承中的
public void run(){
//重写内容
牛逼牛逼,我都不记得了!
重写是父类与子类之间多态性的表现,如果在子类中定义的某方法与父类中的某方法具有相同的名称和参数,知识方法的实现不同,我们就说该方法被重写了;
重载是一个类中多态性的表现,如果在一个类中定义了多个同名的方法,它们或有不同的参数个数或有不同的参数类型,则称为方法的重载;
重新 顾名思义是重新写这个函数,能重新写的函数说明是已经存在过的,只能是子类继承父类的函数,涉及到的是两个类。
重载 重新加载,针对的是一个函数,是一个类中相同方法名,而其参数类型或者个数不同的函数
A和C 重载是方法名相同而里面的参数不同,重写是在子类中可定义与父类中已定义的方法同名而内容不同的方法,这种多态也被称为覆盖(重写)
重写是一种动态的多态表现,重载则是一种静态的表现、重载的返回值类型可以相同可以不同,而重写返回值类型则必须相同
重写是继承父类之后重写父类的方法,重载是一个类提供了同名的方法,但是参数不同天。
这道题你会答吗?花几分钟告诉大家答案吧!
阅读以下程序段,...
扫描二维码,关注牛客网
下载牛客APP,随时随地刷题
京ICP备号-4
扫一扫,把题目装进口袋}

我要回帖

更多关于 java 重写 重载 的文章

更多推荐

版权声明:文章内容来源于网络,版权归原作者所有,如有侵权请点击这里与我们联系,我们将及时删除。

点击添加站长微信