java 反射略窥
java支持反射。很多开源框架了扩展性也会用到反射。
一。反射的缺点:
(1)反射屏蔽了业务逻辑,阅读起来不直观。
(2)性能比直接执行的代友性能要差。但随着JDK版本升级,对反射的处理不断优化,这块并不是太大的问题。
(3)针对java的面向对象思想中的封装,是推荐使用反射的。java的反射可以对方法和属性进行操作。在java中对于属于注入有三种方式:构造方法,set方法,还有反射。依据封装的设计理念,出于对私有属性的保护,不希望直接操作属性,而反射恰恰绕过保护,直接操作属性。
二。代码分析
package file.utils;import java.lang.reflect.Method;import java.util.HashMap;import java.util.Map;class ReflectDemo{ private static int NUM = 10000; public void execute() {try{ System.out.print(""); for (int i = 0; i < 10; i++) {Map<String,String> map = new HashMap<String,String>();map.put(String.valueOf(i), String.valueOf(i)); }}catch (Exception e){ e.printStackTrace();} } public static void main(String[] args) {try{ long flag = System.currentTimeMillis(); ReflectDemo tempDemo = new ReflectDemo(); for (int i = 0; i < NUM; i++) {Method method = ReflectDemo.class.getMethod("execute", null);method.invoke(tempDemo, null); } System.out.println(System.currentTimeMillis() - flag); flag = System.currentTimeMillis(); for (int i = 0; i < NUM; i++) {ReflectDemo demo = new ReflectDemo();demo.execute(); } System.out.println(System.currentTimeMillis() - flag); ReflectDemo demo = new ReflectDemo(); Method method = ReflectDemo.class.getMethod("execute", null); flag = System.currentTimeMillis(); for (int i = 0; i < NUM; i++) {method.invoke(demo, null); } System.out.println(System.currentTimeMillis() - flag);}catch (Exception e){ e.printStackTrace();} }}
运行结果:
79
15
16
分析:
反射的性能消耗在于检查和校验。在执行方法上和正常执行的效果差不多。慢也慢不多少。
如果执行前加上Xint来禁止JIT编译,再看下执行结果:
312
234
250