1. 方法重载:这个是发生在编译时的。方法重载也被称为编译时多态,因为编译器可以根据参数的类型来选择使用哪个方法。
方法覆盖:这个是在运行时发生的。方法覆盖被称为运行时多态,因为在编译期编译器不知道并且没法知道该去调用哪个方法。JVM会在代码运行的时候做出决定。
泛型(又称类型检验):这个是发生在编译期的。编译器负责检查程序中类型的正确性,然后把使用了泛型的代码翻译或者重写成可以执行在当前JVM上的非泛型代码。这个技术被称为“类型擦除“。换句话来说,编译器会擦除所有在尖括号里的类型信息,来保证和版本1.4.0或者更早版本的JRE的兼容性。
注解(Annotation):你可以使用运行时或者编译时的注解。
@Override是一个简单的编译时注解,它可以用来捕获类似于在子类中把toString()写成tostring()这样的错误。
面向切面的编程(Aspect Oriented Programming-AOP):切面可以在编译时,运行时或,加载时或者运行时织入。
继承 – 发生在编译时,因为它是静态的
Java语言本身不支持运行时继承,但是有一种替代的方案叫做“代理”或者“组合”,它表示在运行时组件一个层次对象的子类。这样可以模拟运行时继承的实现。在Java里,代理的典型实现方式如下:
子类代理了父类的调用。组合可以按照下面的方式来实现:
方法覆盖:这个是在运行时发生的。方法覆盖被称为运行时多态,因为在编译期编译器不知道并且没法知道该去调用哪个方法。JVM会在代码运行的时候做出决定。
泛型(又称类型检验):这个是发生在编译期的。编译器负责检查程序中类型的正确性,然后把使用了泛型的代码翻译或者重写成可以执行在当前JVM上的非泛型代码。这个技术被称为“类型擦除“。换句话来说,编译器会擦除所有在尖括号里的类型信息,来保证和版本1.4.0或者更早版本的JRE的兼容性。
- List<String> myList = new ArrayList<String>(10);
- //编译后成为了:
- List myList = new ArrayList(10);
注解(Annotation):你可以使用运行时或者编译时的注解。
- public class B extends A {
- @Override
- public int compute(int input){ //method #4
- return 4 * input;
- }
- }
@Override是一个简单的编译时注解,它可以用来捕获类似于在子类中把toString()写成tostring()这样的错误。
面向切面的编程(Aspect Oriented Programming-AOP):切面可以在编译时,运行时或,加载时或者运行时织入。
继承 – 发生在编译时,因为它是静态的
Java语言本身不支持运行时继承,但是有一种替代的方案叫做“代理”或者“组合”,它表示在运行时组件一个层次对象的子类。这样可以模拟运行时继承的实现。在Java里,代理的典型实现方式如下:
- public class Parent {
- public String saySomething( ) {
- return “Parent is called”;
- }
- }
- public class Child {
- public String saySomething( ) {
- return new Parent( ).saySomething( ) + “, Child is called”;
- }
- }
子类代理了父类的调用。组合可以按照下面的方式来实现:
- public class Child {
- private Parent parent = null;
- public Child( ){
- this.parent = new Parent( );
- }
- public String saySomething( ) {
- return this.parent.saySomething( ) + “, Child is called”;
- }
- }