有关普通方法调用和发射动态方法调用的效率测试
今天关于java中反射机制对程序运行效率的影响进行小小的测试。代码是网上找的,在这就没有放出来了,主要是为了熟悉一下它们之间的效率到底差了多少倍,当备忘录来使用。
声明了一个User对象后,在for循环之前调用一个system.currentTimeMillis()方法,得到当前的时间,然后在for循环中执行getName()方法,执行10亿次后再得到当前的时间,两个时间相减就得到了程序运行的时间。然后三种方法进行比较:
1.普通方法调用;
2.反射动态方法调用;
3.反射动态方法调用,并使用setAccessible()方法跳过安全检查;
运行结果如下:
由上图得知 第一种方法最快,第二种方法是第一种的30倍,第三种方法是第一种的7倍。所以当必须使用反射处理大量数据时,可以选择跳过安全检查以保证相对的效率。