我一定错过了一些非常基本的东西。当我试图在方法调用期间传递任何类型的数组时,我会得到一个错误。但是,当我这样做时,它正常工作。
这是失败的完整代码
import java.lang.reflect.Method;
public class Main {
public static void main(String[] args) throws Exception {
// Normal
MyClass.sayHello(new String[] {"StackOverflow"});
// Reflection
Method m = MyClass.class.getMethod("sayHello", String[].class);
m.invoke(null, new String[]{"StackOverflow"});
}
static class MyClass {
public static void sayHello(String[] args) {
System.out.println("Hello " + args[0]);
}
}
}
Exception in thread "main" java.lang.IllegalArgumentException: argument type mismatch
at sun.reflect.NativeMethodAccessorImpl.invoke0(Native Method)
at sun.reflect.NativeMethodAccessorImpl.invoke(NativeMethodAccessorImpl.java:62)
at sun.reflect.DelegatingMethodAccessorImpl.invoke(DelegatingMethodAccessorImpl.java:43)
at java.lang.reflect.Method.invoke(Method.java:497)
at Main.main(Main.java:11)
String...
也不工作。
问题是invoke
的第二个参数意味着一个参数数组-您只指定一个参数。
在大多数情况下,这将是好的,因为Method.invoke
的第二个参数是一个可变参数,但由于你的参数已经是一个与Object[]
兼容的数组,编译器没有创建一个包装器数组。我希望您得到这样的编译时警告:
Main.java:11: warning: non-varargs call of varargs method with inexact argument type for
last parameter;
m.invoke(null, new String[]{"StackOverflow"});
^
cast to Object for a varargs call
cast to Object[] for a non-varargs call and to suppress this warning
你可以显式地创建一个数组来包装参数,或者将参数强制转换为Object
,这样编译器就需要自己包装它:
// Creates the wrapper array explicitly
m.invoke(null, new Object[] { new String[] { "StackOverflow" } });
或
// Compiler creates the wrapper array because the argument type is just Object
m.invoke(null, (Object) new String[] { "StackOverflow" });