java反射耗时测试案例解析
java反射相对与普通的对象调用原理上来说更加耗时,在调用次数较少的情况下可忽略性能损失,但当调用次数非常多时,需要考虑到此问题,即调用次数过多时不宜使用反射,以下举例:
packagecom.test.reflection;
importjava.lang.reflect.Method;
publicclassReflectionDemo{
publicstaticvoidmain(String[]args)throwsException{
//常规方式
Studentstudent=newStudent();
longstartNormal=System.currentTimeMillis();
for(inti=0;i<1000000;i++){
student.setName("hello");
}
System.out.println("timeNormal="+(System.currentTimeMillis()-startNormal));
//反射方式
Class>cla=Class.forName("com.test.reflection.Student");
longstartReflection=System.currentTimeMillis();
for(inti=0;i<1000000;i++){
Methodmethod=cla.getDeclaredMethod("setName",String.class);
method.invoke(cla.newInstance(),"hello");
}
System.out.println("timeReflection="+(System.currentTimeMillis()-startReflection));
}
}
运行结果:
timeNormal=8 timeReflection=537
这是在简单使用反射调用某个方法的场景下1000000调用的性能差距。
以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持毛票票。