0

我在运行时编译了一个类,我想在运行时使用它,前提是它的构造函数需要一个参数

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)IllegalArgumentExceptionnewInstance

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();

这一切似乎都是同一个问题的一部分,即运行时类似乎与编译不一致,尽管名称匹配。

4

2 回答 2

1

您的 CustomProcessor 类没有构造函数,因为您认为是构造函数的方法的名称不同。

public CustomLatencyProcessor(Manager m) {
    super(m);
}

应改为

public CustomProcessor(Manager m) {
    super(m);
}

因为你的类的名字是CustomProcessor。构造函数的名称必须与其包含的类的名称完全匹配。

于 2013-07-07T23:08:44.790 回答
1

在使用使用 currentThread 作为父级的 URL 之后,我最终能够让它工作(而不是使用 URL 从头开始​​创建的 URLClassLoader)

URLClassLoader ucl = (URLClassLoader)Thread.currentThread().getContextClassLoader();
URLClassLoader ucl2 = new URLClassLoader( new URL[] { new URL( "file://d:/temp/")},ucl);
Class<?> clazz = ucl2.loadClass("com.notmycompany.CustomProcessor");

我希望这可以为您节省 2 天!

于 2013-07-08T10:31:58.197 回答