Mar*_*sen 76 java user-interface multithreading javafx task
我一直在研究这个问题,但至少我还是非常困惑.
谁能给我一个何时使用Task和何时使用的具体例子Platform.runLater(Runnable);?究竟有什么区别?什么时候使用其中任何一个是否有黄金法则?
如果我错了也不纠正我,但这两个"对象"不是在GUI中用于更新GUI的主线程内创建另一个线程的方法吗?
inv*_*ant 94
使用Platform.runLater(...)快速和简单的操作和Task复杂的和大的操作.
示例:为什么我们不能Platform.runLater(...)用于长时间的计算(取自下面的参考).
问题:后台线程只需0到100万,并在UI中更新进度条.
代码使用Platform.runLater(...):
final ProgressBar bar = new ProgressBar();
new Thread(new Runnable() {
@Override public void run() {
for (int i = 1; i <= 1000000; i++) {
final int counter = i;
Platform.runLater(new Runnable() {
@Override public void run() {
bar.setProgress(counter / 1000000.0);
}
});
}
}).start();
Run Code Online (Sandbox Code Playgroud)
这是一段可怕的代码,是对自然的犯罪(以及一般的编程).首先,只要看看Runnables的这种双重嵌套,你就会失去脑细胞.其次,它将使用少量Runnables来淹没事件队列 - 实际上有一百万个.显然,我们需要一些API来更容易编写后台工作程序,然后与UI进行通信.
代码使用任务:
Task task = new Task<Void>() {
@Override public Void call() {
static final int max = 1000000;
for (int i = 1; i <= max; i++) {
updateProgress(i, max);
}
return null;
}
};
ProgressBar bar = new ProgressBar();
bar.progressProperty().bind(task.progressProperty());
new Thread(task).start();
Run Code Online (Sandbox Code Playgroud)
它没有上一个代码中显示的任何缺陷
参考: JavaFX 2.0中的工作线程
ass*_*ias 54
Platform.runLater:如果需要从非GUI线程更新GUI组件,可以使用它来将更新放入队列中,并尽快由GUI线程处理.Task实现Worker当您需要在GUI线程外运行长任务时使用的接口(以避免冻结您的应用程序),但仍需要在某个阶段与GUI交互.如果你熟悉Swing,前者相当于SwingUtilities.invokeLater和后者的概念SwingWorker.
任务的javadoc提供了许多示例,应该阐明如何使用它们.您还可以参考有关并发的教程.
Cag*_*men 10
它现在可以更改为lambda版本
@Override
public void actionPerformed(ActionEvent e) {
Platform.runLater(() -> {
try {
//an event with a button maybe
System.out.println("button is clicked");
} catch (IOException | COSVisitorException ex) {
Exceptions.printStackTrace(ex);
}
});
}
Run Code Online (Sandbox Code Playgroud)
| 归档时间: |
|
| 查看次数: |
130963 次 |
| 最近记录: |