MethodHandle
类的描述中显示的示例在调用WrongMethodTypeException
语句时使用以下描述抛出mh.invokeExact("daddy",'d','n')
:(CC)Ljava/lang/String; cannot be called with a different arity as ([Ljava/lang/Object;)Ljava/lang/Object;
。MethodHandle
对象mh
具有与(CC)Ljava/lang/String
对应的符号类型描述符。但是,当我们调用mh.invokeExact("daddy",'d','n')
时,参数d
和n
作为Object
数组传递,然后它们与char
类型的参数不匹配。
我知道我可以使用invokeWithArguments
而不是invokeExcat
或invoke
来解决上述问题,但是该示例应该可以像Java 7 API的MethodHandle
的描述中所述的那样工作。除此之外,invokeWithArguments
相对于invoke
/invokeExact
具有性能开销。
最佳答案
您如何编译呢?
在我看来,这听起来像是一个已知的Eclipse错误。
我刚刚用javac和以下代码检查过:
import java.lang.invoke.*;
public class ScratchMH {
private static ScratchMH instance = null;
public ScratchMH() {
super();
}
private void run() throws Throwable {
Object x, y; String s; int i;
MethodType mt; MethodHandle mh;
MethodHandles.Lookup lookup = MethodHandles.lookup();
// mt is (char,char)String
mt = MethodType.methodType(String.class, char.class, char.class);
mh = lookup.findVirtual(String.class, "replace", mt);
s = (String) mh.invokeExact("daddy",'d','n');
// invokeExact(Ljava/lang/String;CC)Ljava/lang/String;
System.out.println(s);
}
public static void main(String[] args) throws Throwable {
instance = new ScratchMH();
instance.run();
}
}
似乎可以正常工作:
ariel-2:src boxcat$ javac scratch/clj/ScratchMH.java
ariel-2:src boxcat$ java scratch/clj/ScratchMH
nanny
ariel-2:src boxcat$
javap输出的相关部分似乎也很健全:
35: invokevirtual #8 // Method java/lang/invoke/MethodHandles$Lookup.findVirtual:(Ljava/lang/Class;Ljava/lang/String;Ljava/lang/invoke/MethodType;)Ljava/lang/invoke/MethodHandle;
38: astore 6
40: aload 6
42: ldc #9 // String daddy
44: bipush 100
46: bipush 110
48: invokevirtual #10 // Method java/lang/invoke/MethodHandle.invokeExact:(Ljava/lang/String;CC)Ljava/lang/String;
51: astore_3
关于java - MethodHandle示例在invokeExact调用上引发WrongMethodTypeException,我们在Stack Overflow上找到一个类似的问题:https://stackoverflow.com/questions/8803115/