我在运行时编译了一个类,我想在运行时使用它,前提是它的构造函数需要一个参数
package com.notmycompany;
import com.mycompany.Manager;
import com.mycompany.Processor;
import com.mycompany.Event;
public class CustomProcessor extends Processor {
public CustomProcessor( Manager m) {
super( m);
}
@Override
public void process( Event evt) {
// Do you own stuff
System.out.println( "My Own Stuff");
}
}
编译顺利,我可以立即加载课程。但是构造函数让我很难过。
Class<?> clazz = urlClassLoader.loadClass("com.notmycompany.CustomProcessor");
Constructor<?> constructor = clazz.getConstructor( com.mycompany.Manager.class);
this.customProcessor = (Processor) constructor.newInstance( this.manager);
在这种情况下,getConstructor
抛出一个NoSuchMethodException
我尝试使用的方法,这只会让我在通话期间getConstructors
更进一步(当然 this.manager 是 com.mycompany.Manager)IllegalArgumentException
newInstance
Constructor<?> list[] = clazz.getConstructors();
Constructor<?> constructor = list[0];
this.customProcessor = (Processor) constructor.newInstance( this.manager);
不管我做什么,运行时的 Manager 对象和编译之间存在不匹配
我该如何修复这个构造函数签名?
编辑 1: getParameterTypes 输出
for( Class<?> c : constructor.getParameterTypes()) {
System.out.println( c);
}
输出
class com.mycompany.Manager
编辑2:我删除了构造函数参数作为临时解决方法
现在代码抛出ClassCastException
抱怨com.notmycompany.CustomProcessor cannot be cast to com.mycompany.Processor
调用构造函数时:
Constructor<?> constructor = clazz.getConstructor();
this.customProcessor = (Processor) constructor.newInstance();
这一切似乎都是同一个问题的一部分,即运行时类似乎与编译不一致,尽管名称匹配。