1. 泛型类:当类中要操作的引用数据类型不确定的时候,早期定义Object来完成扩展,现在可以使用泛型类。
2. 泛型方法:为了让不同方法可以操作不同类型,而且类型还不确定,可以将泛型定义在方法上。
格式:
class Demo{
public void show(T t){
System.out.println("show:"+t);
}
public void print(Q q){
System.out.println("print:"+q);
}
public static void method(W t){
System.out.println("method:"+t);
}
}
3.静态方法不可以访问类上定义的泛型。因为类上定义的泛型在创建对象时才被明确。如果静态方法操作的应用数据类型不确定,可以将泛型定义在方法上。
4. 方法中定义泛型时,泛型符号“<>”要放在返回类型之前,修饰符之后。
5. 如果在泛型方法中定义了与泛型类重名的泛型标识,泛型方法将覆盖泛型类中的标识。如下:
public class Test{
public static void main(String[] args){
Demo d=new Demo();
d.show("hello");
d.show(20);
}
}
class Demo{
public void show(T t){
System.out.println("show:"+t);
}
}
将输出:show:helloshow:20
实际上方法并不受实例化对象时定义泛型的影响。
6. 如果Foo是Bar的一个子类型(子类或者子接口),而G是具有泛型生命的类或接口,G并不是G的子类型!这一点非常值得注意,因为它与我们的习惯看法不同。
枚举
1)每个枚举类型都继承自java.lang.Enum类,枚举中的每个成员默认都是public static final的。
2)每个枚举的成员其实就是枚举类型的一个实例。
3)枚举是一种特殊的类,它一样可以有自己的Field、方法,可以实现多个接口。
4)枚举类的构造器只能使用private访问修饰符,且枚举类的所有实例必须在枚举类的第一行显示列出。
5)遍历枚举,例:
for(Color c : Color.values()){
System.out.println(c);
}
6)枚举只有一个成员时,就可以作为一种单例的实现方式。
类加载机制
1)当我们调用Java命令运行某个Java程序时,该命令将会启动一个Java虚拟机进程,不管该java程序有多么复杂,该程序启动了多少个线程,它们都处于该Java虚拟机进程里。
2)当程序主动使用某个类时,如果该类还未被加载到内存中,则系统会通过加载、连接、初始化3个步骤来对该类进行初始化。
3)类加载指的是将类的class文件读入内存,并为之创建一个java.lang.Class对象,也就是说,当程序中使用任何类时,系统都会为之建立一个java.lang.Class对象。
4)当使用ClassLoader类的loadClass()方法来加载某个类时,该方法只是加载该类,并不会执行该类的初始化。使用Class的forName()静态方法才会导致强制初始化该类。
5)当JVM启动时,会形成由3个类加载器组成的初始类加载器层次结构。
Bootstrap ClassLoader:根类加载器负责加载Java的核心类。它并不是java.lang.ClassLoader的子类。
Extension ClassLoader:扩展类加载器它负责加载JRE的扩展目录(%中JAR包的类。
System ClassLoader:系统类加载器它负责在JVM启动时加载来自来获取系统类加载器。
反射
1)所谓反射,就是把Java类中的各种成分映射成相应的Java类。4
2)获取某个类或某个对象所对应的Class对象的常用3种方式:
a)使用Class类的静态方法forName:Class.forName()。
b)使用实例的getClass()方法(继承自Object的方法)。
c)直接使用类名.class,如:String.class。