java 反射 速度_java 反射访问变量速度测试(jdk1.8)

该博客通过测试分析了Java中直接访问字段、JDK反射以及Cglib反射访问的速度差异。结果显示,直接访问最快,约为78毫秒,其次是Cglib反射,约75毫秒,而JDK反射耗时较长,大约190毫秒。测试使用了User类的一个字段,并进行了百万次操作。
摘要由CSDN通过智能技术生成

一百万次字段访问时间简单统计:

直接访问的耗时(78毫秒左右)

jdk反射访问耗时(190毫秒左右)

jdk反射访问(除去getDeclaredField)耗时(80毫秒左右)

cglib访问的耗时(75毫秒左右)

public class ReflectionTest {

static class User{

private String name;

public User() {

}

public String getName() {

return name;

}

public void setName(String name) {

this.name = name;

}

}

/**

* 测试直接访问的耗时(78毫秒左右)

*/

@Test

public void testDirectAccess(){

countTime(user -> user.getName());

}

/**

* 测试jdk反射访问耗时(190毫秒左右)

*/

@Test

public void testJdkReflectionAccess(){

countTime(user -> {

final Class extends User> userClass = user.getClass();

try {

final Field name = userClass.getDeclaredField("name");

name.setAccessible(true);

return (String) name.get(user);

} catch (Exception e) {

throw new RuntimeException(e);

}

});

}

/**

* 测试jdk反射访问耗时(80毫秒左右)

*/

@Test

public void testJdkReflectionAccess2() throws Exception{

final Field name = User.class.getDeclaredField("name");

countTime(user -> {

try {

name.setAccessible(true);

return (String) name.get(user);

} catch (Exception e) {

throw new RuntimeException(e);

}

});

}

/**

* 测试cglib访问的耗时(75毫秒左右)

*/

@Test

public void testCglibReflectionAccess(){

final FastClass fastClass = FastClass.create(User.class);

final FastMethod name = fastClass.getMethod("getName", null);

countTime(user -> {

try {

return (String) name.invoke(user,null);

} catch (InvocationTargetException e) {

throw new RuntimeException(e);

}

});

}

private void countTime(Function function) {

final User user = new User();

user.setName("test");

final Instant start = Clock.systemDefaultZone().instant();

String name = "";

for(int i=0;i<1000*1000;i++){

name = function.apply(user) + i;

}

final long millis = Duration.between(start, Clock.systemDefaultZone().instant()).toMillis();

System.err.println(name);

System.err.println(millis);

}

}

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值