Java中反射性能测试

本文涉及的产品
性能测试 PTS,5000VUM额度
简介:

Java反射效率到底如何,花了点时间,做了一个简单的测试.供大家参考.

测试背景: 
1. 测试简单Bean(int,Integer,String)的set方法
2. loop 1亿次
3. 测试代码尽可能避免对象的创建,复发方法的调用,仅仅测试set方法的耗时

测试结果:

 场景

 本机测试结果(XP,双核,2G)

服务器测试结果(Linux,XEN虚拟机,8核,5.5G)

方法直接调用

235MS

190MS

JDK Method调用

29188MS

4633MS

JDK Method调用(稍作优化)

5672MS

4262MS

Cglib FastMethod调用

5390MS

2787MS


得出一个感性的结果: 
1.JDK反射效率是直接调用的一个数量级,差不多20倍
2.一个set方法的反射调用时间 = 4633ms / 1亿 / 3次 = 0.0154us
3.Cglib的fastmethod还是有优势的

 

当然反射不止一种方法的,而且也有一些比较常见的优化方式。将会测试一下:

直接访问

直接反射

缓存需要查找的函数反射

使用reflectasm的反射

long now;

long sum = 0;

TestClass t = new TestClass();

 

now = System.currentTimeMillis();

for(int i = 0; i<500000; ++i){

    t.setNum(i);

    sum += t.getNum();

}

System.out.println("get-set耗时"+(System.currentTimeMillis() - now) + "ms秒,和是" +sum);

 

sum = 0;

now = System.currentTimeMillis();

for(int i = 0; i<500000; ++i){

    Class<?> c =Class.forName("test.TestClass");

    Class<?>[] argsType = newClass[1];

    argsType[0] = int.class;

    Method m =c.getMethod("setNum", argsType);

    m.invoke(t, i);

    sum += t.getNum();

}

System.out.println("标准反射耗时"+(System.currentTimeMillis()- now) + "ms,和是" +sum);

 

sum = 0;

Class<?> c = Class.forName("test.TestClass");

Class<?>[] argsType = new Class[1];

argsType[0] = int.class;

Method m = c.getMethod("setNum", argsType);

now = System.currentTimeMillis();

for(int i = 0; i<500000; ++i){

    m.invoke(t, i);

    sum += t.getNum();

}

System.out.println("缓存反射耗时"+(System.currentTimeMillis()- now) + "ms,和是" +sum);

 

sum = 0;

MethodAccess ma = MethodAccess.get(TestClass.class);

int index = ma.getIndex("setNum");

now = System.currentTimeMillis();

for(int i = 0; i<500000; ++i){

    ma.invoke(t, index, i);

    sum += t.getNum();

}

System.out.println("reflectasm反射耗时"+(System.currentTimeMillis() - now) + "ms,和是" +sum);

 

测试结果: 
get-set耗时6ms秒
标准反射耗时1838ms
缓存反射耗时70ms
reflectasm反射耗时20ms

可以看出查找函数依然是耗时最长的部分,JDK7的优化确实很不错,由JDK6的40倍降到10倍左右,reflectasm invoke的效率比java原生invoke好,大致是直接访问的4倍时间。效率确实可以一用。


原帖地址:http://www.cnblogs.com/zhishan/p/3195771.html

相关实践学习
通过性能测试PTS对云服务器ECS进行规格选择与性能压测
本文为您介绍如何利用性能测试PTS对云服务器ECS进行规格选择与性能压测。
目录
相关文章
|
20天前
|
Java 测试技术 Maven
Java一分钟之-PowerMock:静态方法与私有方法测试
通过本文的详细介绍,您可以使用PowerMock轻松地测试Java代码中的静态方法和私有方法。PowerMock通过扩展Mockito,提供了强大的功能,帮助开发者在复杂的测试场景中保持高效和准确的单元测试。希望本文对您的Java单元测试有所帮助。
49 2
|
1月前
|
Java 流计算
Flink-03 Flink Java 3分钟上手 Stream 给 Flink-02 DataStreamSource Socket写一个测试的工具!
Flink-03 Flink Java 3分钟上手 Stream 给 Flink-02 DataStreamSource Socket写一个测试的工具!
37 1
Flink-03 Flink Java 3分钟上手 Stream 给 Flink-02 DataStreamSource Socket写一个测试的工具!
|
27天前
|
Java 程序员 测试技术
Java|让 JUnit4 测试类自动注入 logger 和被测 Service
本文介绍如何通过自定义 IDEA 的 JUnit4 Test Class 模板,实现生成测试类时自动注入 logger 和被测 Service。
23 5
|
27天前
|
存储 Java
[Java]反射
本文详细介绍了Java反射机制的基本概念、使用方法及其注意事项。首先解释了反射的定义和类加载过程,接着通过具体示例展示了如何使用反射获取和操作类的构造方法、方法和变量。文章还讨论了反射在类加载、内部类、父类成员访问等方面的特殊行为,并提供了通过反射跳过泛型检查的示例。最后,简要介绍了字面量和符号引用的概念。全文旨在帮助读者深入理解反射机制及其应用场景。
20 0
[Java]反射
|
1月前
|
存储 人工智能 Java
将 Spring AI 与 LLM 结合使用以生成 Java 测试
AIDocumentLibraryChat 项目通过 GitHub URL 为指定的 Java 类生成测试代码,支持 granite-code 和 deepseek-coder-v2 模型。项目包括控制器、服务和配置,能处理源代码解析、依赖加载及测试代码生成,旨在评估 LLM 对开发测试的支持能力。
38 1
|
2月前
|
安全 Java 索引
Java——反射&枚举
本文介绍了Java反射机制及其应用,包括获取Class对象、构造方法、成员变量和成员方法。反射允许在运行时动态操作类和对象,例如创建对象、调用方法和访问字段。文章详细解释了不同方法的使用方式及其注意事项,并展示了如何通过反射获取类的各种信息。此外,还介绍了枚举类型的特点和使用方法,包括枚举的构造方法及其在反射中的特殊处理。
65 9
Java——反射&枚举
|
1月前
|
安全 Java 测试技术
🌟Java零基础-反射:从入门到精通
【10月更文挑战第4天】本文收录于「滚雪球学Java」专栏,专业攻坚指数级提升,希望能够助你一臂之力,帮你早日登顶实现财富自由🚀;同时,欢迎大家关注&&收藏&&订阅!持续更新中,up!up!up!!
26 2
|
2月前
|
安全 Java API
【Java面试题汇总】Java基础篇——String+集合+泛型+IO+异常+反射(2023版)
String常量池、String、StringBuffer、Stringbuilder有什么区别、List与Set的区别、ArrayList和LinkedList的区别、HashMap底层原理、ConcurrentHashMap、HashMap和Hashtable的区别、泛型擦除、ABA问题、IO多路复用、BIO、NIO、O、异常处理机制、反射
【Java面试题汇总】Java基础篇——String+集合+泛型+IO+异常+反射(2023版)
|
1月前
|
IDE Java 编译器
java的反射与注解
java的反射与注解
16 0
|
1月前
|
分布式计算 Java 大数据
大数据-122 - Flink Time Watermark Java代码测试实现Tumbling Window
大数据-122 - Flink Time Watermark Java代码测试实现Tumbling Window
34 0