重载
在同一个类中,方法名相同但参数列表不同的方法互为重载方法(与修饰符,返回值无关)。
public class Demo {
public void print() {
}
public int print(int a) {
return a;
}
}
上述两个print方法互为重载方法。
重写
在父类和子类中方法名称,参数列表都相同的方法。
public class Demo {
public void print() {
}
}
public class Demo1 extends Demo {
public void print() {
}
}
上述例子Demo1重写了父类的print()方法。在重写中方法的修饰符和返回值类型、抛出异常也不一定要相同,但是要满足一定的条件。
重写方法的返回值可以和父类方法返回值一样,或者是父类方法返回值的子类。返回值可以说是目的或要求,子类作为父类的拓展,肯定是要精益求精的。
public class Demo {
public Object print() {
return 1;
}
}
public class Demo1 extends Demo {
public Integer print() {
return 1;
}
}
重写方法的可见性要比父类方法的可见性一致或者更好。重写方法本来就是对父类方法的一种"发扬光大",肯定要具备更好的可见性:
public class Demo {
Object print() {
return 1;
}
}
public class Demo1 extends Demo {
public Integer print() {
return 1;
}
}
无论父类方法是否抛出异常,重写方法都可以抛出一些非强制性异常(空指针异常等一些运行时异常),但不可以抛出一些强制性异常。你在拓展父类方法的过程中可以出现一些小毛病,但你不能错的太离谱。
public class Demo {
Object print() {
return 1;
}
}
public class Demo1 extends Demo {
public Integer print() {
return 1;
}
}
总结
重载是在类中的,方法名相同而参数列表不同就是重载,它与修饰符或者返回值类型无关。它是一个编译器的概念,遵循所谓的"编译器绑定"(根据参数类型判断调用哪个方法),也有人说它是一种编译器多态,但它实质上并不是多态,只是一个语法特性而已。
重写是在父类和子类之间的,方法签名(方法名和参数列表)相同的方法,重写方法会将父类方法覆盖,它也不需要修饰符,返回值类型或者抛出异常一定与父类方法一致,但是它也满足一定的条件。重写是一个运行时的概念,遵循所谓的"运行时绑定"(在运行时根据引用变量来确定调用哪个方法),算是Java继承和多态两种特性的一个结合。