有关普通方法调用和发射动态方法调用的效率测试
2018-03-26 18:14
295 查看
今天关于java中反射机制对程序运行效率的影响进行小小的测试。代码是网上找的,在这就没有放出来了,主要是为了熟悉一下它们之间的效率到底差了多少倍,当备忘录来使用。
声明了一个User对象后,在for循环之前调用一个system.currentTimeMillis()方法,得到当前的时间,然后在for循环中执行getName()方法,执行10亿次后再得到当前的时间,两个时间相减就得到了程序运行的时间。然后三种方法进行比较:
1.普通方法调用;
2.反射动态方法调用;
3.反射动态方法调用,并使用setAccessible()方法跳过安全检查;
运行结果如下:
由上图得知 第一种方法最快,第二种方法是第一种的30倍,第三种方法是第一种的7倍。所以当必须使用反射处理大量数据时,可以选择跳过安全检查以保证相对的效率。
声明了一个User对象后,在for循环之前调用一个system.currentTimeMillis()方法,得到当前的时间,然后在for循环中执行getName()方法,执行10亿次后再得到当前的时间,两个时间相减就得到了程序运行的时间。然后三种方法进行比较:
1.普通方法调用;
2.反射动态方法调用;
3.反射动态方法调用,并使用setAccessible()方法跳过安全检查;
运行结果如下:
由上图得知 第一种方法最快,第二种方法是第一种的30倍,第三种方法是第一种的7倍。所以当必须使用反射处理大量数据时,可以选择跳过安全检查以保证相对的效率。
相关文章推荐
- eval执行效率测试 ——直接调用方法传递参数和通过eval方法调用并传递参数 耗时比较
- 有关静态方法和普通方法的调用
- 代码演示 .NET 中普通方法的调用、反射调用、动态(Dynamic)调用的区别
- 动态调用有关的方法?
- poi 遍历excel行列 读写文件 反射(动态调用方法) 下载 (测试代码)
- C# 三种动态调用WebService的方法,测试通过
- 有关Struts2_ActionMethod_DMI_动态方法调用的学习
- 极限测试之Matlab与Forcal普通函数调用效率
- 有关静态方法和普通方法的调用
- 在ActiveX控件中如何动态调用DLL函数之"准"一体化方法
- 通过字符串调用方法得到结果及动态创建Swing组件和布局
- Struts2.xml文件中的常量、全局错误的配置及相关动态方法的调用
- struts.enable.DynamicMethodInvocation = true 动态方法调用
- 在普通类中调用Service,Dao的方法
- 反射动态调用、实例化窗体的方法
- struts2静态方法和动态方法调用
- C语言调用动态库中的函数的方法(dlopen,dlsym等)
- Qt5.9动态调用c++的dll方法(Qt5.9调用MQTT的一个实例)
- struts2.5动态方法调用不能使用问题
- Unity3D Transform中有关旋转的属性和方法测试