------Java培训、Android培训、iOS培训、.Net培训、期待与您交流! -------
一、类加载器:
类加载器作用:将.class文件转换为字节码加载入内存
1、系统默认的主要类加载器:(类加载器也是java类)
BootStrap、ExtClassLoader、AppClassLoader
当JVM内核启动,BootStrap已经被加载,不需要其他类加载器加载了。
ExtClassLoader类加载器的父级别类加载器是BootStrap
2、构造方法:ClassLoader()
ClassLoader(ClassLoader parent) //使用委托操作的父类加载器创建新类加载器
3、类加载器委托机制:
虚拟机要加载一个类,类加载器要先去加载线程中第一个类
A类引用B类,则使用加载器A的类加载器来加载B类
(或直接调用ClassLoader.loadClass()方法指定某个类加载器去加载某个类)
当类加载器加载类,先委托上级类加载器
委托模式:每个ClassLoader只能加载特定位置的类,可委托其他类加载器去加载类
4、自定义类加载器:
自定义类加载器要继承ClassLoad
类加载器内部实现了父类委托机制,无需自己覆盖loadClass,需要覆盖findClass方法,
当loadClass调用findClass方法,得到了字节码文件。
因为类加载器不知道需要加载的类在什么地方,这时候要调用findClass方法,自定义加载器才能找到
你需要加载的类在哪。
二、泛型机制:
泛型: (安全机制)
使用泛型将一个集合的元素限定为一个特定类型,只能存储一个类型的对象,更加安全。
当获取元素时,也知道了这个对象的类型,不需要强制类型转换了。
好处:1,将运行时期的问题ClassCastException转到了编译时期。(类型转换异常)
2,避免了强制转换的麻烦。
什么时候用?当操作的引用数据类型不确定的时候。就使用<>。将要操作的引用数据类型传入即可.
其实<>就是一个用于接收具体引用数据类型的参数范围。
在程序中,只要用到了带有<>的类或者接口,就要明确传入的具体引用数据类型 。
泛型技术是给编译器使用的技术,用于编译时期。确保了类型的安全。
运行时,会将泛型去掉,生成的class文件中是不带泛型的,这个称为泛型的擦除。
为什么擦除呢?因为为了兼容运行的类加载器。
泛型的补偿:在运行时,通过获取元素的类型进行转换动作。不用使用者在强制转换了。
(非静态)public<w> void show(W str){}
/**
* 当方法静态时,不能访问类上定义的泛型。如果静态方法使用泛型,
* 只能将泛型定义在方法上。
* @param obj
*/
public static <Y> void method(Y obj){
System.out.println("method:"+obj);
}
//泛型接口,将泛型定义在接口上。
interface Inter<T>{
public void show(T t);
}
class InterImpl2<Q> implements Inter<Q>{
public void show(Q q){
System.out.println("show :"+q);
}
}
到调用时再明确对象类型
泛型的通配符:? 未知类型。 arrayList<?>
泛型的限定:? extends E: 接收E类型或者E的子类型对象。上限
一般存储对象的时候用。比如 添加元素 addAll.
Collection<? Extends Person>
? super E: 接收E类型或者E的父类型对象。 下限。
一般取出对象的时候用。比如比较器。
public static void printCollection(ArrayList<? extends Person> ls1) {
Iterator<? extends Person> iterator = ls1.iterator();
while (iterator.hasNext()) {
Person person=iterator.next();
System.out.println(person.getAge());
}
三、代理:
1、代理的作用:
为多个具有相同接口的目标类的方法增加功能
可编写一个与目标类具有相同接口的代理类,代理类的每个方法要调用目标类的相同方法,
并在调用时加上系统功能的代码。