Intellij IDEA - JavaFX 编译问题
Intellij IDEA - problem with JavaFX compilation
我已经将 OS 从 Win7 重新安装到 10。重新安装 Intellij IDEA + Corretto_11 + JavaFX 库后,我无法编译正在运行的程序。
我在 Java 方面还很新手,所以我不知道如何解决这个问题。
项目设置为 Correto_11,语言级别 11,并且 FX 库已添加到模块中。
甚至课程中的代码也无法编译。
Exception in Application start method
java.lang.reflect.InvocationTargetException
at java.base/jdk.internal.reflect.NativeMethodAccessorImpl.invoke0(Native Method)
at java.base/jdk.internal.reflect.NativeMethodAccessorImpl.invoke(NativeMethodAccessorImpl.java:62)
at java.base/jdk.internal.reflect.DelegatingMethodAccessorImpl.invoke(DelegatingMethodAccessorImpl.java:43)
at java.base/java.lang.reflect.Method.invoke(Method.java:566)
at javafx.graphics/com.sun.javafx.application.LauncherImpl.launchApplicationWithArgs(LauncherImpl.java:464)
at javafx.graphics/com.sun.javafx.application.LauncherImpl.launchApplication(LauncherImpl.java:363)
at java.base/jdk.internal.reflect.NativeMethodAccessorImpl.invoke0(Native Method)
at java.base/jdk.internal.reflect.NativeMethodAccessorImpl.invoke(NativeMethodAccessorImpl.java:62)
at java.base/jdk.internal.reflect.DelegatingMethodAccessorImpl.invoke(DelegatingMethodAccessorImpl.java:43)
at java.base/java.lang.reflect.Method.invoke(Method.java:566)
at java.base/sun.launcher.LauncherHelper$FXHelper.main(LauncherHelper.java:1051)
Caused by: java.lang.RuntimeException: Exception in Application start method
at javafx.graphics/com.sun.javafx.application.LauncherImpl.launchApplication1(LauncherImpl.java:900)
at javafx.graphics/com.sun.javafx.application.LauncherImpl.lambda$launchApplication(LauncherImpl.java:195)
at java.base/java.lang.Thread.run(Thread.java:834)
Caused by: java.lang.IllegalAccessError: class com.sun.javafx.fxml.FXMLLoaderHelper (in unnamed module @0x3a0bd002) cannot access class com.sun.javafx.util.Utils (in module javafx.graphics) because module javafx.graphics does not export com.sun.javafx.util to unnamed module @0x3a0bd002
at com.sun.javafx.fxml.FXMLLoaderHelper.<clinit>(FXMLLoaderHelper.java:38)
at javafx.fxml.FXMLLoader.<clinit>(FXMLLoader.java:2056)
at main.Main.start(Main.java:18)
at javafx.graphics/com.sun.javafx.application.LauncherImpl.lambda$launchApplication1(LauncherImpl.java:846)
at javafx.graphics/com.sun.javafx.application.PlatformImpl.lambda$runAndWait(PlatformImpl.java:455)
at javafx.graphics/com.sun.javafx.application.PlatformImpl.lambda$runLater(PlatformImpl.java:428)
at java.base/java.security.AccessController.doPrivileged(Native Method)
at javafx.graphics/com.sun.javafx.application.PlatformImpl.lambda$runLater(PlatformImpl.java:427)
at javafx.graphics/com.sun.glass.ui.InvokeLaterDispatcher$Future.run(InvokeLaterDispatcher.java:96)
at javafx.graphics/com.sun.glass.ui.win.WinApplication._runLoop(Native Method)
at javafx.graphics/com.sun.glass.ui.win.WinApplication.lambda$runLoop(WinApplication.java:174)
... 1 more
Exception running application main.Main
Process finished with exit code 1
编辑:
添加模块后出现以下错误:
"C:\Program Files\Amazon Corretto\jdk11.0.7_10\bin\java.exe" --add-modules javafx.base,javafx.graphics --add-reads javafx.base=ALL-UNNAMED --add-reads javafx.graphics=ALL-UNNAMED "-javaagent:C:\Program Files\JetBrains\IntelliJ IDEA Community Edition 2020.1.1\lib\idea_rt.jar=50795:C:\Program Files\JetBrains\IntelliJ IDEA Community Edition 2020.1.1\bin" -Dfile.encoding=UTF-8 -p C:\Users\Sebastian\Documents\javafx_11\lib\javafx.base.jar;C:\Users\Sebastian\Documents\javafx_11\lib\javafx.graphics.jar;C:\Users\Sebastian\Desktop\JavaProjects\JavaFX_ToDo\out\production\JavaFX_ToDo;C:\Users\Sebastian\Documents\javafx_11\lib\javafx-swt.jar;C:\Users\Sebastian\Documents\javafx_11\lib\javafx.controls.jar;C:\Users\Sebastian\Documents\javafx_11\lib\javafx.fxml.jar;C:\Users\Sebastian\Documents\javafx_11\lib\javafx.media.jar;C:\Users\Sebastian\Documents\javafx_11\lib\javafx.swing.jar;C:\Users\Sebastian\Documents\javafx_11\lib\javafx.web.jar -m JavaFX.ToDo/main.Main
Error occurred during initialization of boot layer
java.lang.module.FindException: Error reading module: C:\Users\Sebastian\Desktop\JavaProjects\JavaFX_ToDo\out\production\JavaFX_ToDo
Caused by: java.lang.module.InvalidModuleDescriptorException: Package JavaFX.ToDo not found in module
Process finished with exit code 1
编辑 2:
项目结构:
编辑 3:
添加我的模块的样子:
module JavaFX.ToDo {
requires javafx.graphics;
requires javafx.controls;
requires javafx.fxml;
opens JavaFX.ToDo;
}
编辑 4:
添加主要内容:
package main;
import javafx.application.Application;
import javafx.fxml.FXMLLoader;
import javafx.scene.Parent;
import javafx.scene.Scene;
import javafx.stage.Stage;
import main.models.TaskData;
import java.io.IOException;
public class Main extends Application {
@Override
public void start(Stage primaryStage) throws Exception{
Parent root = FXMLLoader.load(getClass().getResource("mainwindow.fxml"));
primaryStage.setTitle("JavaFX: ToDo-App");
primaryStage.setScene(new Scene(root, 900, 500));
primaryStage.show();
}
public static void main(String[] args) {
launch(args);
}
@Override
public void stop() throws Exception {
try {
TaskData.getInstance().storeTasks();
} catch (IOException e){
System.out.println(e.getMessage());
}
}
@Override
public void init() throws Exception {
try {
TaskData.getInstance().loadTasks();
} catch (IOException e){
System.out.println(e.getMessage());
}
}
}
或者我可以全力以赴github。
第一个错误发生是因为您的模块未打开,并且 javafx.fxml
模块(特别是 FXMLLoader)想要使用反射。
第二个错误只是因为您使用 opens
不正确。它意味着打开包,而不是模块。
现在这是您的模块信息文件:
module JavaFX.ToDo {
requires javafx.graphics;
requires javafx.controls;
requires javafx.fxml;
opens JavaFX.ToDo; //Here's the error
}
这是不正确的,因为您没有名为 JavaFX.ToDo
的包,这是您的模块名称。要使您的模块打开(因此 javafx.fxml 可以进行反射访问操作),您需要像这样声明您的模块 open
:
open module JavaFX.ToDo {
...
}
xor 这个:
module JavaFX.ToDo {
...
opens main; //This is where Main.java is, and where you use FXMLLoader
}
如果你想让它更安全,你也可以这样声明:
module JavaFX.ToDo {
requires javafx.fxml;
opens main to javafx.fxml; //Only fxml has reflective access to your package now
}
我建议阅读 this article 关于 Java 9 的模块系统。向下滚动到他们谈论开放模块的地方。
旁注:模块名称按照惯例是小写的。你可能想要 javafx_todo
我在 IntelliJ 中按如下方式解决了这个问题:
运行 -> 编辑配置 -> 配置选项卡 -> 在 VM 选项中添加以下内容:
--module-path c:\javafx-sdk-14.0.1\lib --add-modules=javafx.controls,javafx.fxml
我已经将 OS 从 Win7 重新安装到 10。重新安装 Intellij IDEA + Corretto_11 + JavaFX 库后,我无法编译正在运行的程序。
我在 Java 方面还很新手,所以我不知道如何解决这个问题。
项目设置为 Correto_11,语言级别 11,并且 FX 库已添加到模块中。
甚至课程中的代码也无法编译。
Exception in Application start method
java.lang.reflect.InvocationTargetException
at java.base/jdk.internal.reflect.NativeMethodAccessorImpl.invoke0(Native Method)
at java.base/jdk.internal.reflect.NativeMethodAccessorImpl.invoke(NativeMethodAccessorImpl.java:62)
at java.base/jdk.internal.reflect.DelegatingMethodAccessorImpl.invoke(DelegatingMethodAccessorImpl.java:43)
at java.base/java.lang.reflect.Method.invoke(Method.java:566)
at javafx.graphics/com.sun.javafx.application.LauncherImpl.launchApplicationWithArgs(LauncherImpl.java:464)
at javafx.graphics/com.sun.javafx.application.LauncherImpl.launchApplication(LauncherImpl.java:363)
at java.base/jdk.internal.reflect.NativeMethodAccessorImpl.invoke0(Native Method)
at java.base/jdk.internal.reflect.NativeMethodAccessorImpl.invoke(NativeMethodAccessorImpl.java:62)
at java.base/jdk.internal.reflect.DelegatingMethodAccessorImpl.invoke(DelegatingMethodAccessorImpl.java:43)
at java.base/java.lang.reflect.Method.invoke(Method.java:566)
at java.base/sun.launcher.LauncherHelper$FXHelper.main(LauncherHelper.java:1051)
Caused by: java.lang.RuntimeException: Exception in Application start method
at javafx.graphics/com.sun.javafx.application.LauncherImpl.launchApplication1(LauncherImpl.java:900)
at javafx.graphics/com.sun.javafx.application.LauncherImpl.lambda$launchApplication(LauncherImpl.java:195)
at java.base/java.lang.Thread.run(Thread.java:834)
Caused by: java.lang.IllegalAccessError: class com.sun.javafx.fxml.FXMLLoaderHelper (in unnamed module @0x3a0bd002) cannot access class com.sun.javafx.util.Utils (in module javafx.graphics) because module javafx.graphics does not export com.sun.javafx.util to unnamed module @0x3a0bd002
at com.sun.javafx.fxml.FXMLLoaderHelper.<clinit>(FXMLLoaderHelper.java:38)
at javafx.fxml.FXMLLoader.<clinit>(FXMLLoader.java:2056)
at main.Main.start(Main.java:18)
at javafx.graphics/com.sun.javafx.application.LauncherImpl.lambda$launchApplication1(LauncherImpl.java:846)
at javafx.graphics/com.sun.javafx.application.PlatformImpl.lambda$runAndWait(PlatformImpl.java:455)
at javafx.graphics/com.sun.javafx.application.PlatformImpl.lambda$runLater(PlatformImpl.java:428)
at java.base/java.security.AccessController.doPrivileged(Native Method)
at javafx.graphics/com.sun.javafx.application.PlatformImpl.lambda$runLater(PlatformImpl.java:427)
at javafx.graphics/com.sun.glass.ui.InvokeLaterDispatcher$Future.run(InvokeLaterDispatcher.java:96)
at javafx.graphics/com.sun.glass.ui.win.WinApplication._runLoop(Native Method)
at javafx.graphics/com.sun.glass.ui.win.WinApplication.lambda$runLoop(WinApplication.java:174)
... 1 more
Exception running application main.Main
Process finished with exit code 1
编辑:
添加模块后出现以下错误:
"C:\Program Files\Amazon Corretto\jdk11.0.7_10\bin\java.exe" --add-modules javafx.base,javafx.graphics --add-reads javafx.base=ALL-UNNAMED --add-reads javafx.graphics=ALL-UNNAMED "-javaagent:C:\Program Files\JetBrains\IntelliJ IDEA Community Edition 2020.1.1\lib\idea_rt.jar=50795:C:\Program Files\JetBrains\IntelliJ IDEA Community Edition 2020.1.1\bin" -Dfile.encoding=UTF-8 -p C:\Users\Sebastian\Documents\javafx_11\lib\javafx.base.jar;C:\Users\Sebastian\Documents\javafx_11\lib\javafx.graphics.jar;C:\Users\Sebastian\Desktop\JavaProjects\JavaFX_ToDo\out\production\JavaFX_ToDo;C:\Users\Sebastian\Documents\javafx_11\lib\javafx-swt.jar;C:\Users\Sebastian\Documents\javafx_11\lib\javafx.controls.jar;C:\Users\Sebastian\Documents\javafx_11\lib\javafx.fxml.jar;C:\Users\Sebastian\Documents\javafx_11\lib\javafx.media.jar;C:\Users\Sebastian\Documents\javafx_11\lib\javafx.swing.jar;C:\Users\Sebastian\Documents\javafx_11\lib\javafx.web.jar -m JavaFX.ToDo/main.Main
Error occurred during initialization of boot layer
java.lang.module.FindException: Error reading module: C:\Users\Sebastian\Desktop\JavaProjects\JavaFX_ToDo\out\production\JavaFX_ToDo
Caused by: java.lang.module.InvalidModuleDescriptorException: Package JavaFX.ToDo not found in module
Process finished with exit code 1
编辑 2:
项目结构:
编辑 3: 添加我的模块的样子:
module JavaFX.ToDo {
requires javafx.graphics;
requires javafx.controls;
requires javafx.fxml;
opens JavaFX.ToDo;
}
编辑 4:
添加主要内容:
package main;
import javafx.application.Application;
import javafx.fxml.FXMLLoader;
import javafx.scene.Parent;
import javafx.scene.Scene;
import javafx.stage.Stage;
import main.models.TaskData;
import java.io.IOException;
public class Main extends Application {
@Override
public void start(Stage primaryStage) throws Exception{
Parent root = FXMLLoader.load(getClass().getResource("mainwindow.fxml"));
primaryStage.setTitle("JavaFX: ToDo-App");
primaryStage.setScene(new Scene(root, 900, 500));
primaryStage.show();
}
public static void main(String[] args) {
launch(args);
}
@Override
public void stop() throws Exception {
try {
TaskData.getInstance().storeTasks();
} catch (IOException e){
System.out.println(e.getMessage());
}
}
@Override
public void init() throws Exception {
try {
TaskData.getInstance().loadTasks();
} catch (IOException e){
System.out.println(e.getMessage());
}
}
}
或者我可以全力以赴github。
第一个错误发生是因为您的模块未打开,并且 javafx.fxml
模块(特别是 FXMLLoader)想要使用反射。
第二个错误只是因为您使用 opens
不正确。它意味着打开包,而不是模块。
现在这是您的模块信息文件:
module JavaFX.ToDo {
requires javafx.graphics;
requires javafx.controls;
requires javafx.fxml;
opens JavaFX.ToDo; //Here's the error
}
这是不正确的,因为您没有名为 JavaFX.ToDo
的包,这是您的模块名称。要使您的模块打开(因此 javafx.fxml 可以进行反射访问操作),您需要像这样声明您的模块 open
:
open module JavaFX.ToDo {
...
}
xor 这个:
module JavaFX.ToDo {
...
opens main; //This is where Main.java is, and where you use FXMLLoader
}
如果你想让它更安全,你也可以这样声明:
module JavaFX.ToDo {
requires javafx.fxml;
opens main to javafx.fxml; //Only fxml has reflective access to your package now
}
我建议阅读 this article 关于 Java 9 的模块系统。向下滚动到他们谈论开放模块的地方。
旁注:模块名称按照惯例是小写的。你可能想要 javafx_todo
我在 IntelliJ 中按如下方式解决了这个问题: 运行 -> 编辑配置 -> 配置选项卡 -> 在 VM 选项中添加以下内容: --module-path c:\javafx-sdk-14.0.1\lib --add-modules=javafx.controls,javafx.fxml