Animal
public abstract class Animal {
 String name;
 public Animal(String name) {
  this.name = name;
 }
}
Лев
public class Lion extends Animal {
 public Lion(String name) {
  super(name);
  // TODO Auto-generated constructor stub
 }
 public void roar() {
  System.out.println("Roar");
 }
}
Олень
public class Deer extends Animal {
 public Deer(String name) {
  super(name);
 }
 public void runAway() {
  System.out.println("Running...");
 }
}
TestAnimals
public class TestAnimals {
 public static void main(String[] args) {
  Animal lion = new Lion("Geo");
  Animal deer1 = new Deer("D1");
  Animal deer2 = new Deer("D2");
  List<Animal> li = new ArrayList<Animal>();
  li.add(lion);
  li.add(deer1);
  li.add(deer2);
  for (Animal a : li) {
   if (a instanceof Lion) {
    Lion l = (Lion) a;
    l.roar();
   }
   if (a instanceof Deer) {
    Deer l = (Deer) a;
    l.runAway();
   }
  }
 }
}
Есть ли лучший способ итерации по списку без использования? В приведенном выше примере это выглядит нормально, но если у вас много расширений базового класса, тогда нам понадобится так много блоков if.Is там дизайн шаблон или принцип решения этой проблемы?