所谓的继承使子类拥有父类所有的属性和方法其实可以这样理解,子类对象确实拥有父类对象中所有的属性和方法,但是父类对象中的私有属性和方法,子类是无法访问到的,只是拥有,但不能使用。
所以子类对象是绝对大于父类对象的,所谓的子类对象只能继承父类非私有的属性及方法的说法是错误的。可以继承,只是无法访问到而已。当子类覆盖父类的成员变量时,父类方法使用的是父类的成员变量,子类方法使用的是子类的成员变量
- (1)子类覆盖父类的方法,必须有同样的参数返回类型,否则编译不能通过
- (2)子类覆盖父类的方法,在jdk1.5后,参数返回类可以是父类方法返回类的子类
- (3)子类覆盖父类方法,可以修改方法作用域修饰符,但只能把方法的作用域放大,而不能把public修改为private
- ( 4 )子类方法能够访问父类的protected作用域成员,不能够访问默认的作用域成员,除非子类与父类同包
- (5)子类的静态方法不能隐藏同名的父类实例方法
子类不能直接访问父类的私有属性,子类只能在父类中写一个public的getXXX的方法来获取父类中的private属性,子类就调用父类的getXXX来获取private属性
父类中的公有方法和域(属性),在类继承中将会被子类继承,但是私有的将不能被继承。
那么在继承中子类如何才能继承到父类的私有域呢?
答案是:在子类的构造方法中通过super()方法调用父类的构造方法。
也就是,在构造子类的同时,为子类构造出跟父类相同的域。如此就在子类的对象中,也拥有了父类声明的域了。
并且我们也应该这样做:
public class Person{
private String name;
public Person(String name){
this.name = name;
}
public void setName(String name){
this.name = name;
}
public String getName(){
return name;
}
}
public class Student extends Person{
public Student(String name){
super(name);
}
}
Test:
public class TestStudent{
public static void main(String[] args){
Student mStudent = new Student("abc");
String mName = mStudent.getName();
System.out.println("Name is : " + mName);
mStudent.setName("efg");
mName = mStudent.getName();
System.out.println("Name is : " + mName);
}
}
打印结果为:
Name is : abc
Name is efg