java支持反射。很多开源框架了扩展性也会用到反射。
一。反射的缺点:
(1)反射屏蔽了业务逻辑,阅读起来不直观。
(2)性能比直接执行的代友性能要差。但随着JDK版本升级,对反射的处理不断优化,这块并不是太大的问题。
(3)针对java的面向对象思想中的封装,是推荐使用反射的。java的反射可以对方法和属性进行操作。在java中对于属于注入有三种方式:构造方法,set方法,还有反射。依据封装的设计理念,出于对私有属性的保护,不希望直接操作属性,而反射恰恰绕过保护,直接操作属性。
二。代码分析
运行结果:
79
15
16
分析:
反射的性能消耗在于检查和校验。在执行方法上和正常执行的效果差不多。慢也慢不多少。
如果执行前加上Xint来禁止JIT编译,再看下执行结果:
312
234
250
查看源代码:
原因是执行了 checkMemberAccess(Member.PUBLIC, ClassLoader.getCallerClassLoader(), true);
笔者扩展spring mvc框架,其实把method做了缓存。
一。反射的缺点:
(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
查看源代码:
public Method getMethod(String name, Class<?>... parameterTypes)
throws NoSuchMethodException, SecurityException {
// be very careful not to change the stack depth of this
// checkMemberAccess call for security reasons
// see java.lang.SecurityManager.checkMemberAccess
checkMemberAccess(Member.PUBLIC, ClassLoader.getCallerClassLoader(), true);
Method method = getMethod0(name, parameterTypes);
if (method == null) {
throw new NoSuchMethodException(getName() + "." + name + argumentTypesToString(parameterTypes));
}
return method;
}
原因是执行了 checkMemberAccess(Member.PUBLIC, ClassLoader.getCallerClassLoader(), true);
笔者扩展spring mvc框架,其实把method做了缓存。