gpt4 book ai didi

java - 在最小化的 RDP session 中调用重绘时 Swing 使用大量 CPU

转载 作者:搜寻专家 更新时间:2023-10-30 21:34:41 24 4
gpt4 key购买 nike

在 VM 中运行 Swing 应用程序时,我观察到 Java 8(多个版本,尤其是 1.8.0_111)出现了一些奇怪的行为。 VM 是在 VMware 中运行的 Windows 10 机器,我正在对其进行远程桌面操作。我没有尝试使用实际桌面而不是 VM 来执行此操作,但我计划尽快删除一个额外的故障点。

我已经成功地用这个最小程序重现了它:

public static void main(String[] args) {
SwingUtilities.invokeLater(() -> {
JFrame frame = new JFrame();
frame.setDefaultCloseOperation(JFrame.EXIT_ON_CLOSE);
JPanel panel = new JPanel();
for (int i = 0; i < 3; i++) {
JPanel subpanel = new JPanel();
JComboBox<?> box = new JComboBox<>();
subpanel.add(box);
panel.add(subpanel);
}
frame.add(panel);
frame.pack();
frame.setVisible(true);

Timer timer = new Timer(1000, e -> {
frame.repaint();
});
timer.setRepeats(true);
timer.start();
});
}

现在,如果我正常启动它,它会重新绘制,完全没有问题,正如预期的那样,只有一个包含 3 个空组合框的框架。如果我最小化 RDP session 窗口,就会出现问题。如果发生这种情况(并且框架未图标化),Swing 将开始消耗大量 CPU,直到我再次打开 RDP 窗口。

我已经尝试进一步最小化代码示例,但是将组合框计数减少到 2,删除 subpanel 或设置单次触发计时器(而不是重复,即使重绘会发生而 RDP 最小化)都阻止了错误的发生。

这是 CPU 利用率图:
http://i67.tinypic.com/23rwglx.png

我已经尝试在这些峰值期间对应用程序进行分析,以尝试查看究竟发生了什么。这是 JVisualVM 中分析器的结果:
http://i68.tinypic.com/apdwed.png

和采样器(移除包过滤器后):
http://i67.tinypic.com/2071735.png

我无法轻易看出是什么在 ProcessingRunnable 中耗尽了 CPU。有没有人体验过 Swing 突然没有屏幕可以绘制时会做什么?

最佳答案

我已将此作为错误报告发布给 Oracle。我会在链接出现任何细节(被接受或拒绝)时更新此答案。

一对similar bugs已经发布了“无法重现”作为解决方案,但是它们不涉及虚拟机,仅涉及 RDP session (我无法通过 RDPing 到我的工作桌面而不是虚拟机来触发此错误)。

我确实找到了一个解决方法 - 显然从 D3D 堆栈切换并强制使用 OpenGL 堆栈(-Dsun.java2d.d3d=false 启动时的选项)可以防止这种情况发生。我现在添加了一些代码来检查应用程序是否在 VM 上启动并相应地设置选项。

编辑
错误报告已被接受,但目前处于“无法重现”状态。 http://bugs.java.com/bugdatabase/view_bug.do?bug_id=JDK-8191018

关于java - 在最小化的 RDP session 中调用重绘时 Swing 使用大量 CPU,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/46006654/

24 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com