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调用的性能差距。
以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持毛票票。