文字列の配列を引数としてメソッドに渡すことにより、別のクラスから静的メソッドを実行するメソッドを作成しようとしています。
これが私が持っているものです:
public static void
executeStaticCommand(final String[] command, Class<?> provider)
{
Method[] validMethods = provider.getMethods();
String javaCommand = TextFormat.toCamelCase(command[0]);
for (Method method : validMethods) {
if (method.getName().equals(javaCommand)) {
try {
method.invoke(null, new Object[] { new Object[] { command } });
} catch (IllegalAccessException e) {
e.printStackTrace();
} catch (InvocationTargetException e) {
Throwable ex = e.getCause();
ex.printStackTrace();
}
break;
}
}
}
そのような:
String[] args = new String[] { "methodName", "arg1", "arg2" };
executeStaticCommand(args, ClassName.class);
これを実行する必要があります:
public class ClassName {
public static void methodName(String[] args) {
assert args[1].equals("arg1");
}
}
しかし、私はIllegalArgumentException
sを取得しています。
2つの問題があります。
String[]
ですが、Object[]
を渡しています問題はすべて内側のtry
ブロックにあるので、そのコードのみを示します。
String[] args = Arrays.copyOfRange(command, 1, command.length - 1);
method.invoke(null, new Object[]{args}); // must prevent expansion into varargs
可変引数の問題を思い出させてくれた 知覚 に感謝します
呼び出そうとしているメソッドは文字列配列を想定していますが、オブジェクト配列をparamとして渡しています。文字列配列に変更します。または、メソッドがObjectを予期している場合は、任意の型を渡すことができます。
method.invoke(null、(Object)command);
この質問 に基づいて、呼び出しは次のようになります
method.invoke(null, command);