【发布时间】:2016-07-21 08:43:53
【问题描述】:
我的 Swing 应用程序有问题。
我有一个SwingWorker,其中有一个 for 循环,它启动 300 多个 oracle 数据库请求并用结果填充几个JTables。
如果我保持 Swing 应用程序窗口未最小化,或者至少在 Windows 资源管理器中部分可见,则批处理可以正常完成。现在,如果我将应用程序最小化,然后返回到 swing 应用程序,它将被冻结。
组件的基本轮廓和颜色将可见,大部分窗口将只是我为其设置的背景颜色(黑色),并且不会显示任何文本。杀死应用程序的唯一方法是终止进程,因为我单击“X”按钮不会关闭窗口。
这是一个常见问题吗?如何预防?
在批处理工作者内部循环:
for(int i=1; i<=maxDepth; i++){
String[] result = getAllLists(database, i);
for(int j=0; j<result.length; j++){
String period=result[j];
for(String name : names){
System.out.println("New Query: "+name+ " " + period + " | " + "Loading " + (days) + " days x " + years + " years --- ");
if(isValid(period,name)){
List<TickHistory> queryResult = model.getByDaysMultiple(name,period,days+mod+daysHeadroom,years, false);
getModelTableData(name, period, DatabaseHelpers.dateToString(lastCob), years,days,queryResult);
populatePricesTable(queryResult, days, false);
view.setNameText(name);
view.setPeriodText(period);
}else{
System.out.println("query invalid");
}
}
}
}
【问题讨论】:
-
你能给我们看一些代码吗?可能你错过了
SwingUtilities.invokeLater()。使用 jvisualvm 检查应用程序也会有所帮助。 -
有什么例外吗?你使用
publish&process正确吗? -
@TamasRev 我在创建主框架、控制器和用于连接数据库的对象的主进程中使用invokelater
-
@CatalinaIsland 我将检查异常,当我将所有控制台输出重定向到 GUI 文本框时,我看不到它们。我没有在我的代码中使用发布和处理。
标签: java swing swingworker