我正在使用Java的反射API,并且正在编写检查给定对象并描述其字段,方法等的方法。
我正在使用getFields()
方法来迭代不同的属性并显示对象内容:
public static void display(Integer i)
{
System.out.println("An integer: " + i);
}
// Basically a method for each primitive type wrapper
public static void display(Object o)
{
for (Field f : c.getFields())
{
System.out.println("A " + o.getClass() + " which is composed of:");
display(f.get(o));
}
}
(为简单起见,省略了其他原始类型和数组。)
尽管
Field
的get
方法返回了Object
,但我认为将为原始类型包装器(整数,字符串等)调用正确的方法,但实际上,仅调用display(Object o)
(不执行隐式向下转换)。就目前而言,我发现的唯一解决方案是,如果可能的话,将对象残酷地贬低:
public static void display(Object o)
{
if (o instanceof Integer)
{
display((Integer) o);
return;
}
else if (o instanceof String
{
...
} // And so on
for (Field f : c.getFields())
{
System.out.println("A " + o.getClass() + " which is composed of:");
display(f.get(o));
}
}
但是,这看起来确实很丑陋,我想知道是否有更优雅的方法来确保调用正确的方法。
有任何想法吗?
在此先感谢StackOverflow的好人!
最佳答案
您想要的就是所谓的“双重调度”,Java不支持。
您可以通过反射来模拟它:检查所有display
方法及其参数类型,并根据对象的运行时类型动态调用其中之一。
对于这个问题,这是不必要的聪明。您的if-else连锁店很好。