反射效率问题

 

反射带来了编程的灵活性,但是他的执行效率相比于常规调用要低。(禁用安全检查可以稍微缓解)

所以最好是在必须得用反射的情况下再用反射。

 

以如下代码为例,通过两种方式调用某个方法1000000000L

private static void test1(){

       User u=new User();

       long startTime=System.currentTimeMillis();

       for(int i=0; i<1000000000L; i++)

              u.getName();

       long endTime=System.currentTimeMillis();

       System.out.println("普通调用方式耗时:"+(endTime-startTime)+"ms");

      

}

 

private static void test2() throws NoSuchMethodException, SecurityException, IllegalAccessException, IllegalArgumentException, InvocationTargetException{

       User u=new User();

       long startTime=System.currentTimeMillis();

      

       Class<? extends User> class1 = u.getClass();

       Method declaredMethod = class1.getDeclaredMethod("getName", null);

       declaredMethod.setAccessible(false);

      

       for(int i=0; i<1000000000L; i++){

              declaredMethod.invoke(u, null);

       }

             

       long endTime=System.currentTimeMillis();

       System.out.println("反射调用方式(禁用安全检查)耗时:"+(endTime-startTime)+"ms");

      

}

 

private static void test3() throws NoSuchMethodException, SecurityException, IllegalAccessException, IllegalArgumentException, InvocationTargetException{

       User u=new User();

       long startTime=System.currentTimeMillis();

      

       Class<? extends User> class1 = u.getClass();

       Method declaredMethod = class1.getDeclaredMethod("getName", null);

      

       for(int i=0; i<1000000000L; i++){

              declaredMethod.invoke(u, null);

       }

             

       long endTime=System.currentTimeMillis();

       System.out.println("反射调用方式耗时:"+(endTime-startTime)+"ms");

      

}


 

 

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值