动态装载
二 classLoader类加载机制
1 并非一次性加载
2 需要的时候加载即运行期间动态加载
3 static语句块在加载后执行一次
4 dynamic语句块每次new新的对象都会执行(等同与构造方法中的语句,少用)
说明:
1,2点是说程序在加载类时,并不是一次性把所有用到的类都加载进去,而是运行到哪里就加载到哪里,是动态的。
三JDK中classloader的分类
classLoader具体来说有四个
bootstrap classloader 负责核心类的加载
extension classloader 负责扩展类的加载
application classloader 负责自定义类的加载
other classloader
说明:
bootstrap classloader和extension classloader由c或汇编语言或c++操作系统本地语言写的。其他的classloader是用java写的。所以其他的classloader也需要由loader进来
四JDK中classloader的层次关系
classloader存在着层次关系,但不是继承。一个classloader要load class时会向上一层报告,查看是否已经load,如果load了就不会再次load。
反射机制
什么是反射?
反射机制就是我们可以通过反射的API接口可以探索运行期间的一个class的内部结构,并且根据他的内部结构来决定方法怎么样调用。
反射机制的核心类
类加载到内存中后就是一个个对象,其方法,属性等等也可以看作是一个对象。
class 类的类型对象,即每个类都有这样的一个属性表示类型。例如:Object.getClass()就可以得到该类的对象,相当于类名.class。
constructor 代表类中的构造方法
field 代表类中的成员变量
method 代表类中的方法
modifier 代表类中的修饰符
这几个类就是我们实现反射机制的关键,首先我们要通过class.forName("XXX")得到加载到内存中XXX的class对象,然后再得到他的方法,成员变量来调用对象的方法。
实现反射的核心代码
package Reflect; import java.lang.reflect.Field; import java.lang.reflect.Method; public class Reflect { public Object invokeTest(String className,String fieldName,Object args){ Object obj=null; try { //得到内存中的class对象 Class> classObj=Class.forName(className); //将class对象示例出来 obj=classObj.newInstance(); //得到指定的属性对象 Field field=classObj.getDeclaredField(fieldName); //拼接处要调用的方法名称 String methodName="set"+fieldName.substring(0,1).toUpperCase()+fieldName.substring(1); //得到指定的方法对象 Method method= classObj.getDeclaredMethod(methodName,field.getType()); //调用该方法 method.invoke(obj, args); } catch (Exception e) { e.printStackTrace(); } return obj; } }