Swing仍可用但已标记弃用,JavaFX需单独引入;二者线程模型不同(EDT vs Application Thread),布局与打包方式差异显著,JavaFX依赖模块化且具现代UI能力。

Swing 和 JavaFX 在 JDK 11+ 中的实际可用性
Java 11 起,JavaFX 已从 JDK 中剥离,Swing 仍保留在 java.desktop 模块中,但官方明确标记为 @Deprecated(forRemoval = true)(自 JDK 17 起)。这意味着:你还能用 Swing,但新项目不建议启动;JavaFX 不再随 JDK 自带,必须单独引入依赖或分发 SDK。
- Swing 编译运行仍正常,但 IDE 可能提示弃用警告(如
JFrame、JButton) - JavaFX 项目若未配置
javafx-controls、javafx-fxml等模块,会直接抛NoClassDefFoundError: javafx/application/Application - OpenJDK 构建(如 Temurin、Zulu)默认不含 JavaFX;部分厂商 JDK(如 Liberica JDK)可选 bundled 版本
事件线程模型差异直接影响 UI 响应逻辑
Swing 使用单线程 EDT(Event Dispatch Thread),所有 UI 更新必须在 EDT 内执行;JavaFX 使用 Application Thread,且对线程安全更严格——非 FX 线程修改控件属性会立即抛 IllegalStateException: Not on FX application thread。
- Swing 中常用
SwingUtilities.invokeLater()或invokeAndWait()切回 EDT - JavaFX 中必须用
Platform.runLater()包裹 UI 更新代码 - 后台任务:Swing 推荐
SwingWorker;JavaFX 推荐Task+Service,而非裸线程
Platform.runLater(() -> {
label.setText("Done");
progressBar.setProgress(1.0);
});
布局管理器与 FXML 的实际协作成本
Swing 的 GroupLayout、GridBagLayout 学习门槛高,且代码易冗长;JavaFX 默认推荐 FXML + Controller 分离,但 FXML 文件需配套编译、资源路径敏感、IDE 支持参差(尤其 IntelliJ 对 @FXML 注入有时不自动识别)。
- 纯代码写 JavaFX 布局(如
VBox、HBox、BorderPane)比 Swing 更直观,嵌套结构一目了然 - FXML 中引用自定义控件需声明
fx:use-declarations="true"并确保类在 classpath,否则加载时抛ClassNotFoundException - Swing 没有等效的“声明式 UI”标准方案;Scene Builder 导出的 FXML 无法直接用于 Swing
打包与部署时最常卡住的两个点
Swing 应用可直接 jar -cf 打包,只要 JRE 存在就能运行;JavaFX 必须处理模块化和原生库依赖,否则 Windows 上可能报 UnsatisfiedLinkError: Can't load library: ...jfxwebkit.dll,Linux/macOS 则缺 libglass.so 或 libjavafx_font.dylib。
Delphi 7应用编程150例 CHM全书内容下载,全书主要通过150个实例,全面、深入地介绍了用Delphi 7开发应用程序的常用方法和技巧,主要讲解了用Delphi 7进行界面效果处理、图像处理、图形与多媒体开发、系统功能控制、文件处理、网络与数据库开发,以及组件应用等内容。这些实例简单实用、典型性强、功能突出,很多实例使用的技术稍加扩展可以解决同类问题。使用本书最好的方法是通过学习掌握实例中的技术或技巧,然后使用这些技术尝试实现更复杂的功能并应用到更多方面。本书主要针对具有一定Delphi基础知识
立即学习“Java免费学习笔记(深入)”;
- Maven 项目需用
javafx-maven-plugin(非maven-assembly-plugin)生成可执行镜像 - Gradle 用户注意:
javafxPlugin与application插件共存时,run任务默认不加载 JavaFX 模块,需显式配置jvmArgs加--module-path和--add-modules - JavaFX 17+ 强制要求模块名(如
--add-modules javafx.controls,javafx.fxml),漏一个就启动失败
Swing 的兼容性优势只在存量维护场景成立;JavaFX 的现代特性(CSS 样式、动画 API、WebView、硬件加速)不是“锦上添花”,而是决定能否实现某些交互效果的根本条件。别在 JavaFX 里硬套 Swing 思维,比如试图复用 ActionListener —— 它根本不存在于 JavaFX 的事件体系中。










