我正在编写一个能够处理频繁更新的JTable。通常,这个JTable有大约1000行数据,而且有些列会经常更新,因为它们的价值来源于在市场时间内移动很多的股票价格。
我面临的问题是当大量的行(例如80%)正在更新时,JTable变得非常慢,持续20-30秒左右,分析器显示EDT线程非常繁忙,处理tableChanged调用。
我试图通过删除更改 1)抑制fireTableCellUpdated 2)如果有< = 50行更改,请在各行上调用fireTableRowUpdate 3)如果有> 50行更改,为整个表调用fireTableDataChanged。
它更好,但是当频繁更新时仍然很慢,我的理解是fireTableDataChanged也很慢。因此,如果数据更新频繁,将频繁调用fireTableDataChanged,并且GUI会感觉迟钝。
在此主题中有经验的人可以推荐使用fireTableRowsUpdate的最佳做法, fireTableDataChanged和fireTableStructureChanged可以提高GUI的活力和性能?如果您有指向解决此问题的示例代码的指针,那就更好了。
非常感谢
Anthony Si
答案 0 :(得分:7)
我已经做到了,事实上,即使在强大的设置上,默认的JTable性能也非常糟糕。但是所有希望都不会丢失:使用(相当)一些技巧可以获得可接受的表现。
基本上,Oracle有一个专门用于此目的的教程称为“圣诞树”。
在这里,“如何创建表现良好的经常更新的JTable”:
http://www.oracle.com/technetwork/java/christmastree-138396.html
我发现真正令人惊奇的一件事就是不断展示所使用的内存:你可能想要这样做。
你会惊讶于默认的JTable产生了多少不必要的垃圾,减慢了所有的速度,并且当然比它应该更频繁地使用GC触发方式。
然后开始实施我给你的链接中给出的所有技巧,你会发现一切都将运行多更顺畅。我现在正在运行非常复杂且“不断更新”的JTable,现在一切都很好:)
但是,除了最简单的情况和少量数据之外,默认的JTable实现非常糟糕。