Java反射机制

一、什么是反射机制
简单的来说,反射机制指的是程序在运行时能够获取自身的信息。在java中,只要给定类的名字,
那么就可以通过反射机制来获得类的所有信息。
二、JAVA反射机制主要提供了以下功能:
1.在运行时判断任意一个对象所属的类
2.在运行时构造任意一个类的对象
3.在运行时判断任意一个类所具有的成员变量和方法(通过反射甚至可以调用private方法)
4.在运行时调用任意一个对象的方法(*注意:前提都是在运行时,而不是在编译时)
三、Java 反射相关的API简介:
位于java。lang。reflect包中
–Class类:代表一个类
–Filed类:代表类的成员变量
–Method类:代表类的方法
–Constructor类:代表类的构造方法
–Array类:提供了动态创建数组,以及访问数组的元素的静态方法。该类中的所有方法都是静态方法
四、利用反射机制能获得什么信息
一句话,类中有什么信息,它就可以获得什么信息,不过前提是得知道类的名字,要不就没有后文了
类加载有三种方式:
1、命令行启动应用时候由JVM初始化加载
2、通过Class.forName()方法动态加载
3、通过ClassLoader.loadClass()方法动态加载
首先得根据传入的类的全名来创建Class对象。
Class c=Class.forName(“className”);注明:className必须为全名,也就是得包含包名,比如,cn.netjava.pojo.UserInfo;
Object obj=c.newInstance();//创建对象的实例
OK,有了对象就什么都好办了,想要什么信息就有什么信息了。
获得构造函数的方法
Constructor getConstructor(Class[] params)//根据指定参数获得public构造器

Constructor[] getConstructors()//获得public的所有构造器

Constructor getDeclaredConstructor(Class[] params)//根据指定参数获得public和非public的构造器

Constructor[] getDeclaredConstructors()//获得public的所有构造器 
获得类方法的方法 
Method getMethod(String name, Class[] params),根据方法名,参数类型获得方法

Method[] getMethods()//获得所有的public方法

Method getDeclaredMethod(String name, Class[] params)//根据方法名和参数类型,获得public和非public的方法

Method[] getDeclaredMethods()//获得所以的public和非public方法 
获得类中属性的方法 
Field getField(String name)//根据变量名得到相应的public变量

Field[] getFields()//获得类中所以public的方法

Field getDeclaredField(String name)//根据方法名获得public和非public变量

Field[] getDeclaredFields()//获得类中所有的public和非public方法 

java 代码

package cn.com.reflection;   

import java.lang.reflect.Field;   
import java.lang.reflect.InvocationTargetException;   
import java.lang.reflect.Method;   

public class ReflectTester {   

    /**  
     * 在这个类里面存在有copy()方法,根据指定的方法的参数去 构造一个新的对象的拷贝  
     * 并将他返回  
     * @throws NoSuchMethodException   
     * @throws InvocationTargetException   
     * @throws IllegalAccessException   
     * @throws InstantiationException   
     * @throws SecurityException   
     * @throws IllegalArgumentException   
     */  
    public Object copy(Object obj) throws IllegalArgumentException, SecurityException, InstantiationException, IllegalAccessException, InvocationTargetException, NoSuchMethodException{   

        //获得对象的类型   
        Class classType=obj.getClass();   
        System.out.println("该对象的类型是:"+classType.toString());   

        //通过默认构造方法去创建一个新的对象,getConstructor的视其参数决定调用哪个构造方法   
        Object objectCopy=classType.getConstructor(new Class[]{}).newInstance(new Object[]{});   

        //获得对象的所有属性   
        Field[] fields=classType.getDeclaredFields();   

        for(int i=0;i
            //获取数组中对应的属性   
            Field field=fields[i];   

            String fieldName=field.getName();   
            String stringLetter=fieldName.substring(0, 1).toUpperCase();   

            //获得相应属性的getXXX和setXXX方法名称   
            String getName="get"+stringLetter+fieldName.substring(1);   
            String setName="set"+stringLetter+fieldName.substring(1);   

            //获取相应的方法   
            Method getMethod=classType.getMethod(getName, new Class[]{});   
            Method setMethod=classType.getMethod(setName, new Class[]{field.getType()});   

            //调用源对象的getXXX()方法   
            Object value=getMethod.invoke(obj, new Object[]{});   
            System.out.println(fieldName+" :"+value);   

            //调用拷贝对象的setXXX()方法   
            setMethod.invoke(objectCopy,new Object[]{value});   


        }   

        return objectCopy;   

    }   


    public static void main(String[] args) throws IllegalArgumentException, SecurityException, InstantiationException, IllegalAccessException, InvocationTargetException, NoSuchMethodException {   
        Customer customer=new Customer();   
        customer.setName("hejianjie");   
        customer.setId(new Long(1234));   
        customer.setAge(19);   

        Customer customer2=null;   
        customer2=(Customer)new ReflectTester().copy(customer);   
        System.out.println(customer.getName()+" "+customer2.getAge()+" "+customer2.getId());   

        System.out.println(customer);   
        System.out.println(customer2);   


    }   

}   


class Customer{   

    private Long id;   

    private String name;   

    private int age;   


    public Customer(){   

    }   

    public int getAge() {   
        return age;   
    }   


    public void setAge(int age) {   
        this.age = age;   
    }   


    public Long getId() {   
        return id;   
    }   


    public void setId(Long id) {   
        this.id = id;   
    }   


    public String getName() {   
        return name;   
    }   


    public void setName(String name) {   
        this.name = name;   
    }   

}  

java 代码
package cn.com.reflection;   

import java.lang.reflect.Array;   

public class ArrayTester1 {   

    /**  
     * 此类根据反射来创建  
     * 一个动态的数组   
     */  
    public static void main(String[] args) throws ClassNotFoundException {   

        Class classType=Class.forName("java.lang.String");   

        Object array= Array.newInstance(classType,10);  //指定数组的类型和大小   

         //对索引为5的位置进行赋值   
        Array.set(array, 5, "hello");   

        String s=(String)Array.get(array, 5);   

        System.out.println(s);   


        //循环遍历这个动态数组   
        for(int i=0;i<((String[])array).length;i++){   

            String str=(String)Array.get(array, i);   

            System.out.println(str);   
        }   

    }   

补充classloader;
对于ClassLoader的机制是必须要熟悉的基础知识,本文针对Java ClassLoader的机制做一个简要的总结.
JDK默认ClassLoader
JDK 默认提供了如下几种ClassLoader

Bootstrp loader
Bootstrp加载器是用C++语言写的,它是在Java虚拟机启动后初始化的,它主要负责加载%JAVA_HOME%/jre/lib,-Xbootclasspath参数指定的路径以及%JAVA_HOME%/jre/classes中的类。

ExtClassLoader
Bootstrp loader加载ExtClassLoader,并且将ExtClassLoader的父加载器设置为Bootstrp loader.ExtClassLoader是用Java写的,具体来说就是 sun.misc.Launcher$ExtClassLoader,ExtClassLoader主要加载%JAVA_HOME%/jre/lib/ext,此路径下的所有classes目录以及java.ext.dirs系统变量指定的路径中类库。

AppClassLoader
Bootstrp loader加载完ExtClassLoader后,就会加载AppClassLoader,并且将AppClassLoader的父加载器指定为 ExtClassLoader。AppClassLoader也是用Java写成的,它的实现类是 sun.misc.Launcher$AppClassLoader,另外我们知道ClassLoader中有个getSystemClassLoader方法,此方法返回的正是AppclassLoader.AppClassLoader主要负责加载classpath所指定的位置的类或者是jar文档,它也是Java程序默认的类加载器。
如何自定义ClassLoader,这个大家可以自行了解

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值