Наличие цепочки операций «instanceof» считается «запахом кода».Стандартный ответ «использовать полиморфизм».Как бы я это сделал в этом случае?
Есть несколько подклассов базового класса;Ни один из них не под моим контролем.Аналогичная ситуация была бы с классами Java Integer, Double, BigDecimal и т. Д.
if (obj instanceof Integer) {NumberStuff.handle((Integer)obj);}
else if (obj instanceof BigDecimal) {BigDecimalStuff.handle((BigDecimal)obj);}
else if (obj instanceof Double) {DoubleStuff.handle((Double)obj);}
У меня есть контроль над NumberStuff и т. Д.
Я не хочу использовать много строккода, где будет делать несколько строк.(Иногда я делаю HashMap, сопоставляющий Integer.class с экземпляром IntegerStuff, BigDecimal.class с экземпляром BigDecimalStuff и т. Д. Но сегодня я хочу что-то попроще.)
Мне бы хотелось что-то простое, например:
public static handle(Integer num) { ... }
public static handle(BigDecimal num) { ... }
Но Java просто так не работает.
Я бы хотел использовать статические методы при форматировании.Вещи, которые я форматирую, составные, где Thing1 может содержать массив Thing2s, а Thing2 может содержать массив Thing1s.У меня была проблема, когда я реализовал мои средства форматирования следующим образом:
class Thing1Formatter {
private static Thing2Formatter thing2Formatter = new Thing2Formatter();
public format(Thing thing) {
thing2Formatter.format(thing.innerThing2);
}
}
class Thing2Formatter {
private static Thing1Formatter thing1Formatter = new Thing1Formatter();
public format(Thing2 thing) {
thing1Formatter.format(thing.innerThing1);
}
}
Да, я знаю HashMap, и немного больше кода может это исправить.Но «instanceof» кажется таким читабельным и понятным для сравнения.Есть ли что-нибудь простое, но не вонючее?
Примечание добавлено 10/10/2010:
Оказывается, что в будущем, возможно, будут добавлены новые подклассы, и мой существующий код должен будет обрабатыватьих изящно.В этом случае HashMap on Class не будет работать, поскольку класс не будет найден.Цепочка операторов if, начиная с самого конкретного и заканчивая самым общим, вероятно, является лучшей из всех:
if (obj instanceof SubClass1) {
// Handle all the methods and properties of SubClass1
} else if (obj instanceof SubClass2) {
// Handle all the methods and properties of SubClass2
} else if (obj instanceof Interface3) {
// Unknown class but it implements Interface3
// so handle those methods and properties
} else if (obj instanceof Interface4) {
// likewise. May want to also handle case of
// object that implements both interfaces.
} else {
// New (unknown) subclass; do what I can with the base class
}