关于多态
1.在java程序语言中,对象变量是多态的。
2.不能讲一个超类的引用赋给子类变量。
3.private方法,static方法,final方法或者构造器,那么编译器将可以准确的知道应该调用哪个方法,我们将这种调用方式称为静态绑定。
4.动态绑定有一个非常重要的特性:无需对现存的代码进行修改,就可以对城乡惊喜扩展。
5.在覆盖一个方法的时候,子类方法不能低于超类方法的可见性。
6.不允许扩展的类被称为final类。
7.如果将一个类声明为final,只用其中的方法自动的成为final,而不包括域。
8.将一个值存入变量时,编译器将检查是否允许该操作。将一个子类的引用赋给一个超类变量,编译器是允许的。但将一个超类的引用赋给一个子类变量,必须进行类型转换,这样才能够通过运行时检查。
9.只能在继承层次内进行类型转换,在将超类转换成为子类前,应该使用instanceof进行检查。
10.不会产生异常,只是返回false。之所以这样处理是因为null没有引用任何对象,当然也不会引用C类型的对象。
11.如果自下而上在类的继承层次结构中上移,位于上层的类更具有通用性,甚至可能更加抽象。
12.为了提高程序的清晰度,包含一个或多个抽象方法的类本身必须被声明为抽的。
13.除了抽象方法之外,抽象类还可以包含具体数据和具体方法。
14.抽象类方法充当着占位的角色,他们的具体实现在子类中。
15.扩展抽象类可以有两种方法:一种是在子类中定义部分抽象方法或抽象方法也不定义,这样就必须将子类也标记为抽象类;另一种是定义全部的抽象方法,使其不抽象。
16.类即使不含抽象方法,也可以将类声明为抽象类。抽象类不能实例化。但可以定义一个抽象类的对象变量。
17.private仅对本类可见,public对所有类可见,protected对本包和所有子类可见,默认修饰符对本包可见。
实例程序:
测试类
public class test001 {
public static void main(String[] arge)
{
Person[] people = new Person[2];
people[0] = new Employee("worker",1000,1987,1,1);
people[1] = new Student("boy","计算机");
for(Person p : people)
{
System.out.println(p.getName() + "," + p.getDescription());
}
}
}
人类
public abstract class Person {
public abstract String getDescription();
private String name;
public Person(String n)
{
name = n;
}
public String getName()
{
return name;
}
}
雇员类
import java.util.*;
public class Employee extends Person {
private double salary;
private Date hireDay;
public Employee(String n,double s,int year,int month,int day)
{
super(n);
salary = s;
GregorianCalendar gr = new GregorianCalendar(year,month - 1,day);
hireDay = gr.getTime();
}
public double getSalary()
{
return salary;
}
public Date getHireDay()
{
return hireDay;
}
public String getDescription()
{
return String.format("一名工资为 %.2f的工人",salary);
}
public void raise(double p)
{
double raise = salary * p / 100;
salary += raise;
}
}
学生类
public class Student extends Person {
private String major;
public Student(String n,String m)
{
super(n);
major = m;
}
public String getDescription()
{
return "一名" + major +"专业的学生";
}
}