java 反射基础

来源:互联网 发布:产品经理绘图软件 编辑:程序博客网 时间:2024/06/10 14:22

一.Class 对象

首先看下Class类,它是final类型的,不允许被继承的,其构造函数是私有的,说明其是单例的。

public final class Class<T> implements java.io.Serializable,                              GenericDeclaration,                              Type,                              AnnotatedElement {    private static final int ANNOTATION= 0x00002000;    private static final int ENUM      = 0x00004000;    private static final int SYNTHETIC = 0x00001000;    private static native void registerNatives();    static {        registerNatives();    }    /*     * Constructor. Only the Java Virtual Machine creates Class     * objects.     */    private Class() {}...}

1.类是程序的一部分,每个类在JVM中有且只有一个Class对象,用来描述类本身的,它是由JVM创建的。

2.对于每个类而言,JRE都为其保留了一个不变的class类型的对象,一个Class对象包含某个类的相关信息。

3.获取Class对象的三种方式

3.1直接通过类名.class 的方法类获取

3.2通过对象调用getClass方法来获取

3.3通过全类名的方法获取,用的较多,框架用的比较多,比如spring中配置

public class ClassTest {    public static void main(String args[]) throws ClassNotFoundException, IllegalAccessException, InstantiationException {        //直接通过类名.class 的方法类获取        Class classStudent = Student.class;        Student student = new Student();        //通过对象调用getClass方法来获取        classStudent = student.getClass();        //通过全类名的方法获取        classStudent = Class.forName("com.hsc.study.Student");        //实际调用是无参构造器去实例化对象的        classStudent.newInstance();    }}

二.类加载器

ClassLoader 

类加载器是用来把类加载到JVM中,JVM规范定义两种类型的类装载器:启动类装载器(bootstrap)和用户自定义装载器。JVM在运行的时候会产生3个类加载器组成初始化加载层次接口。1.Bootstap ClassLoader 引导类加载器:用C++编写,是JVM自带的类加载器,负责java平台的核心库,用来装载核心类库,该加载器无法获取;2.Extension Classloader 扩展类加载器:负责jdk_home/lib/ext 目录下的jar包或者-Djava.ext.dirs指定的目录下的jar包;3.System Classloader 系统类加载器:负责加载java -classpath 或者-Djava.class.path所指点的目录下的类与jar包装入工作。由1->2->3 尝试的去加载类,由3->2->1检查类是否被加载。

public class ClassLoaderTest {    public static void main(String args[]) throws ClassNotFoundException,IOException    {        //系统类加载器:负责java -classpath 或者-Djava.class.path所指的目录下类与jar包导入工作        ClassLoader classLoader=ClassLoader.getSystemClassLoader();        System.out.println("System Classloader: "+classLoader);        //Extension ClassLoader        //负责jdk_home/lib/ext 目录下jar包或者-Djava.ext.dirs 指定定目录下的jar包装入工作        classLoader=classLoader.getParent();        System.out.println("Extension Classloader: "+classLoader);        //Bootstap Classloader 引导类加载器,用C++编写的,是jvm自带的类的加载器,负责java平台核心库用来装载类的核心类库,该加载器无法直接获取        classLoader=classLoader.getParent();        System.out.println("Bootstap Classloader: "+classLoader);        //java 核心库是有引导类加载器加载的        classLoader=Class.forName("java.lang.String").getClassLoader();        System.out.println("java.lang.String Classloader: "+classLoader);        //用户自定义类是系统加载器加载的        classLoader=Class.forName("com.hsc.study.Student").getClassLoader();        System.out.println("com.hsc.study.Student ClassLoader: "+classLoader);        //类加载器可以加载类,也一定可以加载文件,只要放在class路径下        InputStream inputStream=Class.forName("com.hsc.study.Student").getClassLoader().getResourceAsStream("test");    }}

Student类

package com.hsc.study;/** * Created by hsc on 16/11/12. */public class Student {    private String name;    private int age;    public String getName() {        return name;    }    public void setName(String name) {        this.name = name;    }    public int getAge() {        return age;    }    public void setAge(int age) {        this.age = age;    }}

执行结果:

System Classloader: sun.misc.Launcher$AppClassLoader@4b67cf4dExtension Classloader: sun.misc.Launcher$ExtClassLoader@60e53b93Bootstap Classloader: nulljava.lang.String Classloader:nullcom.hsc.study.Student ClassLoader:sun.misc.Launcher$AppClassLoader@4b67cf4d



0 0
原创粉丝点击