차이: 재작성은 하위 클래스가 상위 클래스에 대한 액세스를 허용하는 메소드의 구현 프로세스를 재작성하는 경우이며, 메소드 이름과 매개변수 목록이 동일하며 반환 값이나 형식 매개변수를 변경할 수 없습니다. 오버로딩은 매개변수의 수나 유형이 다른 동일한 이름의 여러 함수가 동일한 메소드 이름과 다른 매개변수 목록을 사용하여 동일한 클래스에 동시에 존재하는 경우입니다.
관련 추천: "Java 비디오 튜토리얼"
Q: Java 오버로딩 및 재작성이란 무엇입니까? 차이점은 무엇입니까?
답변:
Overload(오버로드)는 클래스가 서로 다른 유형의 데이터를 통일된 방식으로 처리하는 수단입니다. 실제 성능은 서로 다른 개수 또는 유형의 동일한 이름을 가진 여러 함수 (반환값 유형은 선택사항이며 반환 유형은 오버로드된 함수를 구별하는 기준으로 사용할 수 없음)가 동일한 클래스에 동시에 존재하는 것은 클래스 내 다형성의 발현입니다(호출할 때). 메소드, 는 다양한 수의 매개변수와 매개변수 유형
에 의해 전달되어 사용할 메소드(다형성)를 결정합니다. 同名函数
(返回值类型可随意,不能以返回类型作为重载函数的区分标准)同时存在于同一个类中,是一个类中多态性的一种表现(调用方法时通过传递不同参数个数和参数类型
来决定具体使用哪个方法的多态性)。
重写(Override)是父类与子类之间的多态性,实质是对父类的函数进行重新定义,如果在子类中定义某方法与其父类有相同的名称和参数则该方法被重写,不过子类函数的访问修饰权限不能小于父类的;若子类中的方法与父类中的某一方法具有相同的方法名、返回类型和参数表,则新方法将覆盖原有的方法,如需父类中原有的方法则可使用 super 关键字。
----------
**重载规则:**必须具有不同的参数列表; 可以有不同的返回类型;可以有不同的访问修饰符;可以抛出不同的异常。
重写规则:参数列表必须完全与被重写的方法相同,否则不能称其为重写;返回类型必须一直与被重写的方法相同,否则不能称其为重写;
访问修饰符的限制一定要大于等于被重写方法的访问修饰符;重写方法一定不能抛出新的检查异常或者比被重写方法申明更加宽泛的检查型异常,譬如父类方法声明了一个检查异常 IOException,在重写这个方法时就不能抛出 Exception,只能抛出 IOException 的子类异常,可以抛出非检查异常。
重载与重写是 Java 多态性
的不同表现。
重写是父类与子类之间多态性的表现,在运行时起作用(动态多态性,譬如实现动态绑定)
而重载是一个类中多态性的表现,在编译时起作用(静态多态性,譬如实现静态绑定)。
问:Java 构造方法能否被重写和重载?
答:
重写是子类方法重写父类的方法,重写的方法名不变,而类的构造方法名必须与类名一致,假设父类的构造方法如果能够被子类重写则子类类名必须与父类类名一致才行,所以 Java 的构造方法是不能被重写
的。而重载是针对同一个的,所以构造方法可以被重载
。
问:下面程序的运行结果是什么,为什么?
public class Demo { public boolean equals( Demo other) { System.out.println("use Demo equals." ); return true; } public static void main(String[] args) { Object o1 =new Demo (); Object o2 =new Demo (); Demo o3 =new Demo (); Demo o4 =new Demo (); if (o1.equals(o2)) { System.out.println("o1 is equal with o2."); } if(o3.equals(o4)) { System.out.println("o3 is equal with o4."); } }}
答:上面程序的运行结果如下。
use Demo equals. o3 is equal with o4.
因为 Demo 类中的 public boolean equals(Demo other) 方法并没有重写 Object 类中的 public boolean equals(Object obj) 方法,原因是其违背了参数规则,其中一个是 Demo 类型而另一个是 Object 类型,因此这两个方法是重载关系(发生在编译时)而不是重写关系;故当调用 o1.equals(o2) 时,o2 是 Object 类型参数,实际上调用了 Object 类中的 public boolean equals(Object obj) 方法
매개변수 목록은 재정의된 메서드와 정확히 동일해야 합니다. 그렇지 않으면 반환 유형이 재정의된 메서드와 항상 동일해야 합니다. 그렇지 않으면 재정의된 메서드를 호출할 수 없습니다. override ;
액세스 한정자 제한은 재정의된 메서드의 액세스 한정자보다 크거나 같아야 합니다. 재정의된 메서드는 새로운 확인된 예외나 재정의된 메서드 선언보다 더 넓은 확인된 예외를 발생해서는 안 됩니다. 상위 클래스 메서드는 확인된 예외 IOException을 선언합니다. 이 메서드를 재정의하는 경우 IOException의 하위 클래스에 대한 예외만 발생할 수 있으며 확인되지 않은 예외는 발생할 수 있습니다. 🎜🎜🎜오버로딩과 재작성은 Java 다형성
의 다른 표현입니다. 🎜오버로딩은 컴파일 시간에 작동하는 클래스의 다형성(정적 바인딩과 같은 정적 다형성)의 표현입니다. 🎜🎜오버로드될 수 있습니다
. 🎜🎜🎜🎜Q: 다음 프로그램의 결과는 무엇이며 그 이유는 무엇입니까? 🎜🎜🎜rrreee🎜답변: 위 프로그램의 실행 결과는 다음과 같습니다. 🎜rrreee🎜Demo 클래스의 public boolean equals(Demo other) 메서드는 Object 클래스의 public boolean equals(Object obj) 메서드를 재정의하지 않기 때문에 매개변수 규칙을 위반하기 때문입니다. 그 중 하나가 Demo입니다. type이고 다른 하나는 Object 유형이므로 이 두 메서드는 재정의되지 않고 오버로드됩니다(컴파일 시 발생). 따라서 o1.equals(o2)가 호출되면 o2는 Object 유형 매개 변수이고 Object 클래스는 실제로 호출되는
의 public boolean equals(Object obj) 메소드는 o1과 o2가 모두 컴파일 타임에 Object 유형이고 Object 클래스의 equals 메소드가 o3.equals를 호출할 때 메모리 주소를 비교하여 false를 반환하기 때문입니다. ( o4), Demo 클래스의 equals(Demo other) 메소드가 실제로 호출됩니다. o3과 o4는 모두 컴파일 타임에 Demo 유형이므로 위와 같은 인쇄가 가능합니다. 🎜위 내용은 Java에서 다시 작성과 오버로딩의 차이점은 무엇입니까의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!