Create by westfallon on 8/10
接口
- 在Java中,接口不是类,而是对类的一组需求描述,这些类要遵从接口描述的统一格式进行定义
接口的特性
- 接口变量必许引用实现了接口的类对象
- 接口中所有的方法都自动地属于public
- 接口中的域将被自动设为public static final
- 接口绝不能含有实例域,也不能在接口中实现方法
- 一个类只能继承一个对象,但可以实现多个接口
对象克隆
- 当拷贝一个变量时,原始变量与拷贝变量引用同一个对象,所以改变一个变量所引用的对象将会对另一个变量产生影响
- 默认的克隆操作是浅拷贝,它并没有克隆包含在对象中的内部变量
- 如果默认的clone方法不能满足要求,则应该
- 实现Cloneable接口
- 使用public修饰符重新定义clone方法
- 在Object中,clone方法被声明为protected,子类只能调用受保护的clone克隆它自己。因此,必须重新定义clone方法,并将它声明为public,这样才能让所有的方法克隆对象
- Cloneable接口是Java提供的几个标记接口之一。通常使用接口是为了确保类实现某个特定的方法或一组特定的方法。而标记接口没有方法,使用它的唯一目的是可以用instanceof进行类型检查
- 为了实现深拷贝,必须克隆所有可变的实例域
回调
- 回调(callback)是一种常见的程序设计模式,在这种模式中,可以指出某个特定的事件发生时应该采取的动作
内部类
- 内部类(inner class)是定义在另一个类中的类,使用内部类的原因有以下三点:
- 内部类方法可以访问该类定义所在的作用域中的数据,包括私有的数据
- 内部类可以对同一个包中的其他类隐藏起来
- 想要定义一个回调函数且不想编写大量代码时,使用匿名(anonymous)内部类比较便捷
- 内部类的对象总有一个隐式引用,它指向了创建它的外部类对象
- 只有内部类可以是私有类,而常规类只可以具有包可见性或公有可见性
- 内部类是一种编译器现象,与虚拟机无关。编译器会把内部类翻译成用 $ 分割外部类名与内部类名的常规类文件,而虚拟机则对此一无所知
- 由于内部类具有访问特权,所以与常规类比较起来功能更强大
局部类
- 局部类不能用public或private访问说明符进行声明,它的作用域被限定在声明这个局部类的块中
- 局部类有一个优势,即对外部世界可以完全的隐藏起来
- 与其他内部类相比,局部类还有一个优点,它们不仅能够访问包含它们的外部类,还可以访问局部变量,不过那些局部变量必许被声明为 final
final
- final的含义是:在创建一个对象后,只能够为之赋值一次,此后再也不能修改它的值
- 在定义final变量时可以不进行初始化
- 定义时没有初始化的final变量通常被称为空final(blank final)变量
匿名内部类
- 假如只创建某个类的一个对象,就不必对这个类命名。这种类被称为匿名内部类(anonymous inner class)
- 匿名类不能有构造器,取而代之的是,将构造器参数传递给超类构造器
- 如何在静态方法中获取当前类的类名?
在这里,new Object(){} 会建立 Object 的一个匿名子类的一个匿名对象,getEnclosingClass() 则得到其外围类,也就是包含这个静态方法的类new Object(){}.getClass().getEnclosingClass();
静态内部类
- 有时候,使用内部类只是为了把一个类隐藏在另外一个类的内部,并不需要内部类引用外围类的对象,为此可以讲内部类声明为static,以便取消产生的引用
- 只有内部类可以被声明为static
代理
- 利用代理可以在运行时创建一个实现了一组给定接口的新类
- 代理类可以在运行时创建全新的类,这样的代理类能够实现指定的接口
代理类的特性
- 代理类是在程序运行期间创建的
- 所有的代理类都扩展于Proxy类
- 所有的代理都覆盖了Object类中的toString、equals和hashCode,这些方法仅仅调用了调用处理器的invoke,Object类中的其他方法没有被重新定义
- 对于特定的类加载器和预设的一组接口来说,只能有一个代理类
- 代理类一定是public和final