基本上,我正在使用客户端服务器架构,因此某些客户端可以在外部修改对象。
我有一家银行:
public class Bank{
private List<BankingOperation> operationList = new ArrayList<BankingOperation>();
public void addOperation(BankingOperation op) {
this.operationList.add(op);
//...
}
我的服务器:
public class ServerBank extends JFrame {
private Bank bank;
private JTable table;
private OperationTableModel model;
public ServerBank() {
this.bank = new Bank();
this.model= new OperationTableModel(this.bank.getOperationList());
table = new JTable(model);
getContentPane().add(new JScrollPane(table), BorderLayout.CENTER);
pack();
}
public static void main (String args[]) throws Exception {
ServerBank frame=new ServerBank();
frame.setDefaultCloseOperation(JFrame.EXIT_ON_CLOSE);
frame.setSize(800,700);
frame.setLocationRelativeTo(null);
frame.setVisible(true);
}
class OperationTableModel extends AbstractTableModel {
private static final long serialVersionUID = 1L;
private List<BankingOperation> operationList;
public String[] colNames = { "Date", "Login", "Customer","Account", "Operation", "Amount", "Final Balance" };
public Class<?>[] colTypes = { String.class, String.class, String.class, String.class, String.class, Integer.class,
Integer.class };
public OperationTableModel(List<BankingOperation> operationList) {
super();
this.operationList = operationList;
}//...
}
客户端可以通过调用addOperation()在Bank operationList中添加一个Operation。
问题是:JTable如何检测并刷新显示?
因为客户端未使用TableModel方法添加操作。他们无法访问此课程。 最重要的是,我不知道在TableModel构造函数中给出整个Bank的操作列表是个好主意......
答案 0 :(得分:1)
通过让客户访问银行使用的内部列表,您可以让他们在银行银行后面做事。有点像真正的银行访问其内部数据库,而不是强迫所有客户通过在线银行应用程序。
您应该为客户端提供一个允许他们执行操作的接口的引用。此接口的实现将控制它们执行的每个操作,并执行所有必要操作。
例如,接口实现的addOperation()
方法不仅会将操作添加到操作列表中,还会触发表模型事件,以便表显示此添加的操作。
这可以直接完成,如果银行封装表模型,或间接地通过银行触发自定义“操作添加”事件。表模型将侦听这些事件,并触发其自己的表模型事件,以便更新表。