运行时类型识别:RTTI(Run-Time Type Identification)是非常有用的机制,维护类的相关信息。多态(polymorphism)是基于RTTI实现的。RTTI的功能主要是由Class类实现的。
Class对象:创建类的所有的“常规”对象。
所有的类都是在对其第一次使用时,动态加载到JVM中。当程序创建第一个对类的静态成员的引用时就会加载这个类。这证明构造器也是类的静态方法,即使在构造器之前并没有使用static关键字。因此使用new操作符创建类的新对象也会被当作对类的静态成员的引用。
类加载器首先检查这个类的Class对象是否已经加载。如果没有加载,默认类加载器就会根据类名查找.class文件。一旦类的Class对象被载入内存,他就会被创建这个类的所有对象。
Class对象仅在需要的时候才被加载,static初始化时在类加载时进行。
Class.forName():取得Class对象的引用。参数时包含目标类的文本名(需要使用全限定名包含包名),返回一个Class对象的引用。生成结果在编译时是不可知的。
Class.newInstance():实现“虚拟构造器”的一种途径,允许:“我不知道你的确切类型,但是无论如何会正确的创建。”
关键字instanceof,返回布尔值,表示对象是不是某个特定类型的实例。检查Class对象时,是这个类或者这个类的派生类。==和equal检查是确切的类型,不考虑继承。
类字面常量:PetCount
反射
提供一种机制:检查可用的方法,并返回方法名。
另一个动机:在运行时获取类的信息。
远程方法调用(RMI):在跨网络的远程平台上创建和运行对象的能力。
注意:在通过反射与一个未知类型的对象打交道时,JVM只是简单的检查这个对象,看它属于那个特定的类,所以需要先加载这个类的Class对象,因此这个类的.class文件必须是被课获取的:要么在本地机器上,要么通过网络获取。反射机制中.class文件在编译时是不可获取的所以在云习惯时打开和检查.class文件。RTTI:编译器在编译时打开和检查.class文件。
用途:对象序列化,JavaBean
类方法提取器:Class的getMethods(),getConstructors()。
代理是基本的设计模式之一。提供额外的或不同丰的操作,而插入的用来代替“实际”对象的对象。
动态代理:动态地创建并动态的处理对所代理方法的调用。在动态代理上所作的所有调用都会被重定向到单一的调用处理器上,它的工作是揭示调用的类型并确定相应的对策。
泛型
可以解决数据安全性的问题。主要原理:在类声明时通过一个标识标识类中的某个属性的类型或者是某个方法的返回值及参数类型。
【访问权限】 类名<泛型类型1,泛型类型2,泛型类型3...> {
【访问权限】 泛型类型标识 变量名称;
【访问权限】 泛型类型标识 方法名称(){};
【访问权限】 泛型类型标识 方法名称(泛型类型标识 变量名称){};
}
注意:泛型的指定必须是一个类,无法设置为基本数据类型譬如int,需要指定为Integer。
好处:避免类型转换异常发生。
最好是在声明类的时候指定泛型,不然会出现安全警告。
通配符
?通配符
匹配任意类型的通配符。适合于对象的引用传递。
注意如果使用了?通配符,那么不能设置被指定类型的内容。但是可设置为null。
譬如:Info<?> name =new Info<String>(); name.setVar("frace")//会产生错误,无法设置。编译不成功。
所有数字包装类都是Number类的子类。
网友评论