我的摇摆应用程序中存在问题。
我有一个SwingWorker
内部有一个for循环,它会启动300多个oracle数据库请求,并用结果填充多个JTable
。
如果我保持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");
}
}
}
}
答案 0 :(得分:3)
我在代码中的任何位置都不使用
publish
和process
。
这可能是问题的根源。 SwingWorker
依赖于在publish()
中调用doInBackground()
并使用process()
更新事件调度线程上的TableModel
。检查完整的示例here。