本文介紹了為什么模塊路徑上的模塊必須使用–Add-Models?的處理方法,對(duì)大家解決問(wèn)題具有一定的參考價(jià)值,需要的朋友們下面隨著小編來(lái)一起學(xué)習(xí)吧!
問(wèn)題描述
一個(gè)例子:自從從JDK中刪除了JavaFX,現(xiàn)在JavaFX SDK以一組模塊化JAR的形式分發(fā)。要編譯一個(gè)JavaFX應(yīng)用程序,當(dāng)然必須將它們放在模塊路徑上:
javac -p /path/to/jars/ App.java
然而,這還不夠。嘗試編譯將導(dǎo)致許多類似
的錯(cuò)誤
sample/App.java:3: error: package javafx.application is not visible
import javafx.application.Application;
^
(package javafx.application is declared in module javafx.graphics, which is not in the module graph)
要解決此問(wèn)題,我們可以使用–Add-MODULES:
添加
javac -p /path/to/jars/ --add-modules javafx.graphics App.java
如果我們向項(xiàng)目中添加了一個(gè)-info.Java模塊(僅包含module ui {}
),則不會(huì)有任何問(wèn)題。
為什么模塊路徑上的模塊對(duì)命名模塊可見(jiàn),但對(duì)未命名模塊不可見(jiàn)?
推薦答案
+1回答一個(gè)非常好的問(wèn)題。這里的問(wèn)題是,當(dāng)您編譯命名模塊和未命名模塊時(shí),它們的默認(rèn)根模塊集的計(jì)算方式非常不同。
這是JEP 261中的一句話,它解釋了這種差異:
當(dāng)編譯器編譯未命名模塊中的代碼或Java
調(diào)用Launcher并加載應(yīng)用程序的主類
從類路徑到應(yīng)用程序類的未命名模塊
加載器,則未命名模塊的缺省根模塊集為
計(jì)算方法如下:如果存在,則java.se模塊是根。如果它不存在,那么
升級(jí)模塊路徑上或系統(tǒng)之間的每個(gè)Java.*模塊
不加限定地導(dǎo)出至少一個(gè)包的模塊是
超級(jí)用戶。升級(jí)模塊路徑上或系統(tǒng)間的每個(gè)非Java.*模塊
不加限定地導(dǎo)出至少一個(gè)包的模塊是
也是根。
這看起來(lái)可能有點(diǎn)復(fù)雜,所以我用粗體顯示了文本中最重要的部分。另外,讓我們一步一步來(lái):
您沒(méi)有module-info.java
,所以您的模塊是一個(gè)未命名的模塊。
java.se
存在,因此它已進(jìn)入根集。
您的升級(jí)模塊路徑為空(因?yàn)槟恢付?code>-p,而沒(méi)有指定--upgrade-module-path
)。
至少導(dǎo)出一個(gè)包的系統(tǒng)模塊也進(jìn)入集合。
因此,根集僅為java.se
和一些系統(tǒng)模塊。沒(méi)有JavaFX模塊進(jìn)入集合!
現(xiàn)在,當(dāng)您使用module-info.java
編譯時(shí)會(huì)發(fā)生什么?使用不同的規(guī)則計(jì)算根集:
否則,默認(rèn)的根模塊集取決于階段:
在編譯時(shí),通常是正在編譯的模塊集
因?yàn)楦K是需要JavaFX模塊的模塊,所以它們進(jìn)入了模塊圖。
那么,如何解決這個(gè)問(wèn)題呢?您可以通過(guò)將JavaFX模塊放在升級(jí)模塊路徑上來(lái)完成此操作:
javac --upgrade-module-path /path/to/jars/ App.java
或使用--add-modules
:
javac -p /path/to/jars/ --add-modules ...
或使用普通老類路徑:
javac -cp /path/to/jars/ App.java
這三個(gè)選項(xiàng)都應(yīng)該有效。讓我知道第一個(gè)選項(xiàng)是否真的有效,因?yàn)槲覜](méi)有嘗試它。
這篇關(guān)于為什么模塊路徑上的模塊必須使用–Add-Models?的文章就介紹到這了,希望我們推薦的答案對(duì)大家有所幫助,