为什么随着参数数量的增加,JDI的invokeMethod呈指数级下降?

问题描述

com.sun.jdi.ClassType.invokeMethod()在完全没有参数的虚拟方法上花费了不到1毫秒的时间。使用6个参数,需要3-4毫秒(方法实现不会改变,参数只是传递给方法,而根本不使用)。对于20个参数,它就像16-17ms。因此,将这些参数传递给该方法大约需要16-17ms。

这是我的方法,称为:

public static void dummy(Object a1,Object a2,Object a3,Object a4,Object a5,Object a6){
//some basic operations which do not depend on the params,can be replaced with Thread.sleep(),or even left empty
}

这就是我所说的:

List<Value> values = new ArrayList<>(map.values());
long l = System.currentTimeMillis();

invokeMethod(threadRef,dummyMethod,values,ObjectReference.INVOKE_SINGLE_THREADED);
   
System.out.println("time:"+ (System.currentTimeMillis() - l));

我也尝试过Varargs,结果更糟。

还有一种解决方法,我可以将所有参数传递给该方法而无需花费大量时间(例如,使用某种包装器)?

更新:我运行了另一个基准测试,我称其为invokeMethod数千次,并计算了总耗时。无参数版本和多参数版本之间的差异太大,可能是由于微基准偏差所致。

解决方法

暂无找到可以解决该程序问题的有效方法,小编努力寻找整理中!

如果你已经找到好的解决方法,欢迎将解决方案带上本链接一起发送给小编。

小编邮箱:dio#foxmail.com (将#修改为@)

相关问答

错误1:Request method ‘DELETE‘ not supported 错误还原:...
错误1:启动docker镜像时报错:Error response from daemon:...
错误1:private field ‘xxx‘ is never assigned 按Alt...
报错如下,通过源不能下载,最后警告pip需升级版本 Requirem...