动态绑定机制使得基类的引用能够指向正确的子类对象,从而使得面向基类编程成为可能。然而动态绑定在以下两种情况会失效。1、基类方法是private或final修饰的这个很好理解,因为private说明该方法对子类是不可见的,子类再写一个同名的方法并不是对父类方法进行复写(Override),而是重新生成一个新的方法,也就不存在多态的问题了。同理也可以解释final,因为方法同样是不可覆盖的。2、方法是static修饰的代码如下所示.class Base { public static void staticMethod() { System.out.println("Base staticMehtod"); } public void dynamicMehtod() { System.out.println("Base dynamicMehtod"); } }class Sub extends Base { public static void staticMethod() { System.out.println("Sub staticMehtod"); } public void dynamicMehtod() { System.out.println("Sub dynamicMehtod"); } }public class TJ4 { public static void main(String args[]) { Base c = new Sub(); c.staticMethod(); c.dynamicMehtod(); } }/* OutPut: Base staticMehtod Sub dynamicMehtod */输出结果并不像设想的那样,输出 "Sub staticMehtod"。因为静态方法是与类而不是与某个对象相关联,c.staticMethod();等同于Car.staticMethod();所以尽量不要使用实例变量去调用静态方法,避免混淆。本文永久更新链接地址:http://www.linuxidc.com/Linux/2016-06/131973.htm