沿用上面的测试方法 , 测试结果如下:

文章插图
invoke和set
修改getReflectCallMethodCostTime和getReflectCallFieldCostTime方法的代码如下 , 对getMethod和getDeclaredField进行测试:
private long getReflectCallMethodCostTime(int count){ long startTime = System.currentTimeMillis(); ProgramMonkey programMonkey = new ProgramMonkey("小明", "男", 12); for(int index = 0 ; index < count; index++){ try{ Method setmLanguageMethod = programMonkey.getClass().getMethod("setmLanguage", String.class); }catch(NoSuchMethodException e){ e.printStackTrace(); } } return System.currentTimeMillis()-startTime;}private long getReflectCallFieldCostTime(int count){ long startTime = System.currentTimeMillis(); ProgramMonkey programMonkey = new ProgramMonkey("小明", "男", 12); for(int index = 0 ; index < count; index++){ try{ Field ageField = programMonkey.getClass().getDeclaredField("mLanguage"); }catch(NoSuchFieldException e){ e.printStackTrace(); } } return System.currentTimeMillis()-startTime;}沿用上面的测试方法 , 测试结果如下:
文章插图
getMethod和getDeclaredField
测试结论:
- getMethod和getDeclaredField方法会比invoke和set方法耗时;
- 随着测试数量级越大 , 性能差异的比例越趋于稳定;
个人猜测应该是和在程序运行时操作class有关 , 比如需要判断是否安全?是否允许这样操作?入参是否正确?是否能够在虚拟机中找到需要反射的类?主要是这一系列判断条件导致了反射耗时;也有可能是因为调用natvie方法 , 需要使用JNI接口 , 导致了性能问题(参照Log.java、System.out.println , 都是调用native方法 , 重复调用多次耗时很明显) 。
如果避免反射导致的性能问题?通过上面的测试可以看出 , 过多地使用反射 , 的确会存在性能问题 , 但如果使用得当 , 所谓反射导致性能问题也就不是问题了 , 关于反射对性能的影响 , 参照下面的使用原则 , 并不会有什么明显的问题:
- 不要过于频繁地使用反射 , 大量地使用反射会带来性能问题;
- 通过反射直接访问实例会比访问方法快很多 , 所以应该优先采用访问实例的方式 。
- 测试频繁调用native方法是否会有明显的性能问题;
- 测试同一个方法内 , 过多的条件判断是否会有明显的性能问题;
- 测试类的复杂程度是否会对反射的性能有明显影响 。
来自:https://www.jianshu.com/p/4e2b49fa8ba1
【Java 反射到底慢在哪?】
推荐阅读
- 拒做PB Boy!教你巧用 Protobuf 反射来优化代码
- Win10的兼容性到底有多强,你甚至可以运行16位的上古程序
- 如何在JavaScript中对对象数组进行排序
- Java内存泄漏、性能优化、宕机死锁的N种姿势
- 排名前5的JavaScript框架
- Linux 上部署 Java 应用绕不开的命令,撒花啦
- 买茶到底去哪里买,买就送玻璃杯萧氏毛尖自饮绿茶茶叶高山云雾茶日照原产嫩芽栗香味浓120g
- java 实现 SelectSort 选择排序算法详解
- 六安瓜片到底怎么样,安徽六安六安瓜片
- 凉水泡茶有什么危害吗,茶烟到底对身体有害吗
