Sta*_*kER 10 java reflection interface
一个简单的界面:
interface Foo {
void myMethod(String arg);
}
class FooImpl implements Foo {
void myMethod(String arg){}
public static void main(String[] args) {
Class cls = FooImpl.class;
try {
for (Method method : cls.getMethods()) {
System.out.print(method.getName() + "\t");
for(Class paramCls : method.getParameterTypes()){
System.out.print(paramCls.getName() + ",");
}
System.out.println();
}
} catch (SecurityException e) {
// TODO Auto-generated catch block
}
}
}
Run Code Online (Sandbox Code Playgroud)
输出将是:
myMethod java.lang.String,
...//Other Method
Run Code Online (Sandbox Code Playgroud)
只打印一个myMethod.
但是,如果我将接口更改为通用接口:
interface Foo<T> {
void myMethod(T arg);
}
class FooImpl implements Foo<String> {
void myMethod(String arg){}
}
Run Code Online (Sandbox Code Playgroud)
然后奇怪的是输出将是:
myMethod java.lang.Object,
myMethod java.lang.String,
...//Other Method
Run Code Online (Sandbox Code Playgroud)
为什么在将接口更改为通用接口后,将导致另一个具有参数类型Object的方法?
第一种方法是由编译器创建的桥接方法.如果你测试' isBridge() '的方法,你可以过滤掉'错误'的方法(也可以过滤出协方差返回时可能得到的一些奇怪的结果).
以下代码不会打印myMethod java.lang.Object:
import java.lang.reflect.Method;
public class FooImpl implements Foo<String> {
public void myMethod(String arg) {
}
public static void main(String[] args) throws Exception {
Class cls = FooImpl.class;
for (Method method : cls.getMethods()) {
if (!method.isBridge()) {
System.out.print(method.getName() + "\t");
for (Class paramCls : method.getParameterTypes()) {
System.out.print(paramCls.getName() + ",");
}
}
System.out.println();
}
}
}
interface Foo<T> {
public void myMethod(T arg);
}
Run Code Online (Sandbox Code Playgroud)
| 归档时间: |
|
| 查看次数: |
980 次 |
| 最近记录: |