尽管这个方法在简单、小型的情况下工作得很好,但是它没有良好的可扩展性。如果你有10个按钮,扩展actionPerformed()方法来测试每个按钮和调用某些对应的操作,会使得可读性非常差。相反,我们好在包含用户接口的类中去掉所有的判定。

  做到这点的一个途径是使用Command模式。当我们使用这个模式的时候,需要我们创立一个Command接口:

//the Command interface
public interface Command{
public void execute();
}


  我们将三个单选按钮扩展成特定的带有Command接口的类,我们可以把对命令的执行从JFrame类转移到每个按钮的类。同时,我们创建一个叫做SexButton的基类,并将ActionListener代码移到基类中,这样不需要分别在每个按钮中添加事件监听器:

//abstract radio button class
public abstract class SexButton
extends JRadioButton implements Command{
protected Swimmers simmers;
//JawList is a subclass of JScrollPane contained a JList;
protected JawList kidList;
public SexButton(String title,Swimmers sw,
JawList klist,ActionListener al){
super(title);
swimmers=sw;
kidList=klist;
addActionListener(al);
}
//abstract execute method
public abstract void execute();
}


  注意这个类必须被扩展以使得它有用,因为我们没有具体化execute()方法。这个基本的抽象按钮类只是我们从中导出的具体类的一个模板,这实际也是模板设计模式的一个简单例子。

//radio button to select female swimmers
public class FemaleButton extends SexButton{
public execute(){
Vector v=swimmers.getList(true);
loadList(v);
}
private void loadList(Vector v){
kidList.clear();
for(int i=0;i
Swimmer swm=(Swimmer)v.elementAt(i);
kidList.add(swm.getName());
}
}
}


  现在,来看一下我们完成的工作。所有的按钮都成为了Command按钮了,actionPerformed()方法也简化成下面这样简单的方法:

public void actionPerformed(ActionEvent e){
Command cmd=(Command)e.getSource();
cmd.execute();
}