在普通Java中,我可以写
class P {
static <A> A id (A x) { return x; }
static int y = P.<Integer>id(8);
static String bar = P.<String>id("foo");
}
在jshell中,我可以声明并使用id
jshell> <A> A id (A x) { return x; }
| created method id(A)
jshell> int x = id(8)
x ==> 8
jshell> String y = id("foo")
y ==> "foo"
但我不知道如何使类型参数显式化。
jshell> String y = <String>id("foo")
| Error:
| illegal start of expression
| String y = <String>id("foo");
| ^
隐含上下文类的名称是什么?
允许我回答这个问题的(部分)jshell规范在哪里? http://openjdk.java.net/jeps/222刚刚提到了一个合成类&#34; in&#34;包装&#34;。听起来不像它可以被命名。
答案 0 :(得分:1)
确实,您的link没有指定将您的方法作为静态方法的同义类的确切性质(如名称)。
我试图通过
获取代码片段正在执行的类jshell> new Exception().printStackTrace()
java.lang.Exception
at REPL.$JShell$17.do_it$($JShell$17.java:8)
at jdk.internal.reflect.NativeMethodAccessorImpl.invoke0(java.base@9-ea/Native Method)
at jdk.internal.reflect.NativeMethodAccessorImpl.invoke(java.base@9-ea/NativeMethodAccessorImpl.java:62)
at jdk.internal.reflect.DelegatingMethodAccessorImpl.invoke(java.base@9-ea/DelegatingMethodAccessorImpl.java:43)
at java.lang.reflect.Method.invoke(java.base@9-ea/Method.java:531)
at jdk.internal.jshell.remote.RemoteAgent.commandLoop(jdk.jshell@9-ea/RemoteAgent.java:124)
at jdk.internal.jshell.remote.RemoteAgent.main(jdk.jshell@9-ea/RemoteAgent.java:62)
jshell> Thread.currentThread().getStackTrace()[1].toString()
$15 ==> "do_it$(java:18)"
jshell> Thread.currentThread().getStackTrace()[1].getClassName()
$16 ==> ""
但正如您所看到的,信息不在堆栈跟踪中。
规避它的最简单方法是将方法定义为自己类中的静态方法:
jshell> class B { static <A> A id(A x) {return x;} }
这允许你拨打
jshell> String y = B.<String>id("foo");
并获得所需的结果。