1.多态
java引用变量有两个类型,一是编译时的类型,二是运行时的类型,编译时类型由声明该变量时使用的类型决定,运行时类型由实际赋给该变量的对象的类型决定。 两个类型不一致时,就会出现多态。
public class BaseClass{
public int a = 10;
public void base(){
System.out.println("父类普通方法");
}
public void test(){
System.out.println("父类被覆盖方法");
}
}
public class SubClass extend BaseClass{
public int a = 5;
public void test(){
System.out.println("子类覆盖父类方法");
}
public void sub(){
System.out.println("子类普通方法");
}
public static void main(String[] args){
//多态
BaseClass p = new SubClass();
//对象的属性不具备多态性,所以下面输出的p的a属性还是父类中的10
System.out.println(p.a);
//下面调用将执行子类中覆盖父类的test()方法
p.test();
//下面代码编译时会出错,因为p无法调用子类中的普通方法sub(),因为编译时只能调用编译类型所具有的方法
//p.sub();
}
}
2.强制类型转换和instanceof运算符
如果我们想要通过上面的引用变量p来访问子类的属性,我们可以将其强制类型转换为子类Subclass q = (SubClass)p
强制类型转换可以将一个基本类型转换为另一个类型,此外,可以将引用类型变量转换为其子类类型,但是要注意:
①:基本类型的转换只能在数值类型之间,指的是整型,浮点型,字符型,不能和布尔型转换。
②:只能把一个父类变量转换为其子类类型,两个互相没有关系的类不能转换,编译会出错;在将一个父类实例转换为子类类型时,该实例实际上必须为子类类型,即运行时类型为子类类型,否则会抛出ClassCastException异常
此时就需要用instanceof运算符,来保证强制类型转换的安全;
基本形式: a instanceof b, a是一个引用类型变量,b是一个类名, a的编译时类型要么和b相同,要么是b的父类否则编译无法通过, 比如:
Object a = "Hello";
//Object是String的父类,编译通过,返回true
a instanceof String;
//Object是Math的父类,编译通过,返回false
a instanceof Math;
String b = "Hello";
//String不是Math的父类,编译不通过
b instanceof Math;