- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
假设一个应用程序读取数据文件,从用户获取一些输入(通过 GUI),从大型数据库获取附加数据并执行冗长的分析。
按照建议,我将耗时的部分(数据库管理和实际分析)删除到了 SwingWorker
实例中。现在执行数据库管理的第一部分工作正常(参见下面的代码):
dialog.addWindowListener(new WindowAdapter() {
@Override
public void windowClosed(WindowEvent e) {
final File dbFile = dialog.getFile();
frame.activateDisGlass("Loading DB, please wait...");
SwingWorker<Void, Void> worker = new SwingWorker<Void, Void>() {
@Override
protected Void doInBackground() throws Exception {
try {
dbman = new DbManager(dbFile);
} catch (SQLException e1) {
System.err.println("Unable to load the chosen database, see details below:");
e1.printStackTrace();
}
return null;
}
@Override
protected void done(){
frame.deactivateDisGlass();
}
};
worker.execute();
}
});
但是,相同的策略在分析案例中无法正常工作。由于分析部分相当长,并且涉及到很多自定义类,我将总结一下情况。以下代码位于一个自定义类中,该类与 GUI 交互以获取用户输入,计算由 analyzeButton
触发,该对象启动多个对象的创建,其中一个对象包含一个线程池并行进行独立分析:
// INITIATE ANALYSIS
analyzeButton.addActionListener(new ActionListener() {
public void actionPerformed(ActionEvent evt) {
for (int i = 0; i < annots.length; i++) {
annots[i] = (ANNOT_TYPE) combos[i].getSelectedItem();
}
// Validate the column annotations
List<ANNOT_TYPE> annotlist = Arrays.asList(annots);
if (!annotlist.contains(ANNOT_TYPE.R) &&
!(annotlist.contains(ANNOT_TYPE.OS1) &&
annotlist.contains(ANNOT_TYPE.OS2))) {
JOptionPane
.showMessageDialog(
null,
"<html>Missing annotation!<p>"
+ "<p> Please make sure you have annotated the datafile correctly...",
"Missing annotation!",
JOptionPane.ERROR_MESSAGE);
return;
}
// Validate DB selection
if (descPanel.getDBManager() == null) {
JOptionPane
.showMessageDialog(
null,
"<html>No database not selected for analysis! <p>"
+ "<p> Please select and load a database..",
"Database error", JOptionPane.ERROR_MESSAGE);
return;
}
// Activate progress indicator
frame.getMainFrame().activateInfiGlass();
SwingWorker<Void, Void> worker = new SwingWorker<Void, Void>() {
@Override
protected Void doInBackground() {
try {
// register parameters
param.addParam(AnalysisParams.value_key,descPanel.getValueTypeComboIndex());
param.addParam(AnalysisParams.sepchar_key,descPanel.getSepCharComboIndex());
paramPanel.registerParams();
StringBuilder sb = new StringBuilder("Data preview completed, initiating analysis...");
sb.append(System.lineSeparator())
.append("... column annotations: ")
.append(Arrays.toString(annots));
logger.info(sb.toString() + System.lineSeparator());
// Create dataset; to be passed on to SwingWorker which will
// execute the analysis
ds = new Dataset();
for (String[] line : data)
ds.addRow(line, annots);
System.out.println("Dataset parsed...");
logger.info("Dataset parsing complete "
+ System.lineSeparator()
+ ds.toString()
+ System.lineSeparator());
conserv = new ConcurrencyService(ds, descPanel.getDBManager());
conserv.serve();
DebugToolbox.dumpScores();
}
} catch (InterruptedException e) {
logger.severe("Concurrency service interrupted"
+ System.lineSeparator()
+ e.getStackTrace()
+ System.lineSeparator());
System.err.println("Interrupt exception!!");
}
return null;
}
@Override
protected void done() {
if(!conserv.isDone())
logger.warning("Concurrency Service is not done!" +
System.lineSeparator());
logger.info("#DEBUG: Conserv should have been terminated by now..." + System.lineSeparator());
frame.getMainFrame().deactivateInfiGlass();
}
};
worker.execute();
}
});
那么问题是什么,您可能会问...问题是 done()
从未在 SwingWorker
上调用,并且应用程序实际上只是挂起,等待某物。我可以看到 doInBackground()
已完成,因为分数已转储到日志文件中(这是该方法中的最后一个操作,但我没有看到 done 的预期输出()
我从 jvisualvm 获得了线程转储,这是相关的部分:
"SwingWorker-pool-1-thread-2" daemon prio=5 tid=0x00007f8ce5819000 nid=0x860b waiting on condition [0x0000000129593000]
java.lang.Thread.State: WAITING (parking)
at sun.misc.Unsafe.park(Native Method)
- parking to wait for <0x0000000705a2c978> (a java.util.concurrent.locks.AbstractQueuedSynchronizer$ConditionObject)
at java.util.concurrent.locks.LockSupport.park(LockSupport.java:186)
at java.util.concurrent.locks.AbstractQueuedSynchronizer$ConditionObject.await(AbstractQueuedSynchronizer.java:2043)
at java.util.concurrent.LinkedBlockingQueue.take(LinkedBlockingQueue.java:442)
at java.util.concurrent.ThreadPoolExecutor.getTask(ThreadPoolExecutor.java:1068)
at java.util.concurrent.ThreadPoolExecutor.runWorker(ThreadPoolExecutor.java:1130)
at java.util.concurrent.ThreadPoolExecutor$Worker.run(ThreadPoolExecutor.java:615)
at java.lang.Thread.run(Thread.java:744)
Locked ownable synchronizers:
- None
前一个 SwingWorker
(加载数据库的那个)具有完全相同的状态和堆栈跟踪,这让我认为 SwingWorker
实际上已经完成了它的工作,但应用程序的其余部分不知何故没有收到通知。
类似问题:我注意到两个相关的问题有本质区别
JDK-7 SwingWorker deadlocks? - 我的 SwingWorker
是(或应该)彼此独立的。
SwingWorker hangs at Unsafe.park() - 我的 SwingWorker
不与 GUI 交互或返回任何内容(null
除外),因此它不应该与 get()
有任何关系,对吗?
想法?
最佳答案
您声明:
so it should not have anything to do with get(), right?
并非如此。调用 get()
是关键,否则您将无法捕获和处理 SwingWorker 的 doInBackground 方法中抛出的任何异常。因此,我建议您不要忘记在 done()
方法中对 SwingWorker 调用 get()
,也许在方法中首先调用它,然后不要不要忘记捕获并分析此方法引发的任何和所有异常。
关于java - SwingWorker 完成后挂起 : Is it bad practise to start and run a thread pool from a SwingWorker?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/24805366/
我有一个应用程序,当通过 eclipse 运行时,它会导致 eclipse 本身挂起。如果我将此应用程序导出为 jar 并运行它,它工作正常。但是,如果我运行(或调试)它,应用程序将显示为启动(根据
我正在将项目从 Rails2 切换到 Rails3。我跑: rails server 服务器启动没有错误: => Booting WEBrick => Rails 3.0.7 application
当我尝试使用 XCode 打开特定项目时,它挂起。当它挂起时,它显示以下屏幕: 其他项目可以正常打开,虽然挂起的项目也打开了,意味着我什么也做不了。我的 CPU 全速运行(风扇开始运转),我必须退出多
我正在使用 BNHtmlPdfKit 将 Html 呈现为 PDF。它工作得很好,但在 iOS8 中它只是挂起 [renderer drawPageAtIndex:i inRect:renderer.
我一直在尝试在 eclipse 中创建一个项目,并且有一个名为 InitRemoteEditJob 的工作正在阻止一切。它甚至没有被取消。 请建议怎么办? 最佳答案 这个错误有很多原因。 你可以试试这
我使用这个函数来发出 cURL 请求: function curl_request($options) //single custom cURL request. { $ch = curl_i
当我尝试归档某个项目时,Xcode 无法响应。如果让他一个人呆着,他会在很长一段时间后设法打开管理器。文件在那里。如果从 library/developer/xcode/archives 中手动删除,
有时我的 Eclipse 挂起,我需要猛烈地杀死它。但是,我一直无法正确地做到这一点。似乎 kill -9 实际上并没有以正确的方式关闭它,因为我仍然可以看到挂起的窗口。什么命令序列会正确杀死我的 E
我有一个JavaFX 8应用,它有时会挂起/冻结。我觉得我已经排除了造成此问题的许多原因,但它仍在发生。 不幸的是,我无法按需复制冻结/挂起。实际上,这仅发生在(到目前为止)我同事的计算机上。它可能在
我正在尝试学习网络基础知识,并且已经从this教程构建了回显服务器。我用telnet检查了服务器,它工作正常。 现在,当我使用Internet上的许多客户端示例中的一些示例时: // Create a
我正在尝试使用 SwiftUI 实现使用 Apple 登录,但在我输入正确的密码后它挂起。 我正在使用真实用户和模拟器以及 XCode 12.0 Beta。不幸的是,我现在没有可供测试的设备。我也尝试
我包括此简单的错误处理功能来格式化错误: date_default_timezone_set('America/New_York'); // Create the error handler. fun
我正在尝试为 VisualVM 安装一些插件,但它一直卡在下面的屏幕上 - 告诉我“请等待安装程序发现插件依赖项”。我运行的是 Ubuntu 12.04。当我尝试从“可用插件”列表中安装它们时,以及当
如果堆分配/取消分配/重新分配在另一个线程中进行,DbgHelp 库的 MiniDumpWriteDump() 将挂起。这是调用堆栈:DbgHelp 暂停其他线程,然后无限期地等待这些线程获得的互斥量
我正在尝试在 Eclipse C++ 版本中安装新软件。 帮助 -> 安装新软件。当我去安装新软件时,它会挂起或需要几个小时才能移动百分比。 我读到这是 JRE7 中的一个已知错误,我假设我在安装它后
这个问题已经有答案了: process.waitFor() never returns (12 个回答) 已关闭 3 年前。 我使用以下代码运行命令: open class AppRunner {
我正在尝试为 VisualVM 安装一些插件,但它一直卡在下面的屏幕上 - 告诉我“请等待安装程序发现插件依赖项”。我正在运行 Ubuntu 12.04。当我尝试从“可用插件”列表安装它们时,以及当我
如果堆分配/取消分配/重新分配在另一个线程中进行,DbgHelp 库的 MiniDumpWriteDump() 将挂起。这是调用堆栈:DbgHelp 暂停其他线程,然后无限期地等待这些线程获得的互斥量
尝试调试竞争条件,其中我们的应用程序的轮询器线程之一永远不会返回,导致 future 的轮询器永远不会被调度。用抽象术语来说,在捕获问题时隐藏我们的业务逻辑,这就是我们的代码路径。 我们必须更新远程服
我在程序完成时遇到 Java 的 ExecutorCompletionService 问题。 我需要使用 ExecutorCompletionService 而不是 ExecutorService 因
我是一名优秀的程序员,十分优秀!