作为序言,我意识到这可能是一个事件调度线程问题。我只是不确定问题到底出在哪里。
我有一个使用 AbstractListModel 查询对象并将结果显示为列表的 JList:
public class View {
public View(final Person person) {
JList list = new JList(new AbstractListModel() {
@Override
public Object getElementAt(int index) {
return person.getSibling(index);
}
@Override
public int getSize() {
return person.getNumSiblings();
}
});
}
最初,JList 看起来不错 - 它显示了所有“Person”都自动构建的同级。但是,当我在代码的另一个区域中使用 person.addSibling(...) 之类的东西时,JList 会变为空白。
这是 EDT 问题吗?(似乎在更新 Person 之后不再调用 AbstractListModel 的方法。)
如果是这样,我应该在哪里添加 SwingWorker 代码 - 在 AbstractListModel 内部还是在 person.addSibling(...) 内部?
谢谢!
编辑:
我正在附加一个简单的可运行版本:
import java.awt.Dimension;
import java.util.ArrayList;
import java.util.List;
import javax.swing.AbstractListModel;
import javax.swing.JFrame;
import javax.swing.JList;
import javax.swing.JPanel;
import javax.swing.SwingUtilities;
public class Test {
public static void main(String[] args) {
final Person person = new Person();
SwingUtilities.invokeLater(new Runnable() {
@Override
public void run() {
try {
JFrame frame = new JFrame();
frame.setPreferredSize(new Dimension(1024, 768));
frame.setDefaultCloseOperation(JFrame.EXIT_ON_CLOSE);
frame.setExtendedState(frame.getExtendedState() | JFrame.MAXIMIZED_BOTH);
JPanel panel = new JPanel();
frame.setContentPane(panel);
JList list = new JList(new AbstractListModel() {
@Override
public Object getElementAt(int index) {
return person.getSibling(index);
}
@Override
public int getSize() {
return person.getNumSiblings();
}
});
panel.add(list);
frame.pack();
frame.setLocationRelativeTo(null);
frame.setVisible(true);
person.addSibling("Bob");
} catch (Throwable ex) {
ex.printStackTrace();
}
}
});
}
private static class Person {
List<String> siblings = new ArrayList<String>();
public Person() {
siblings.add("Janice");
}
public void addSibling(String sibling) {
siblings.add(sibling);
}
public Object getSibling(int index) {
return siblings.get(index);
}
public int getNumSiblings() {
return siblings.size();
}
}
}