您好,登錄后才能下訂單哦!
這篇文章主要講解了“Java9新特性Module模塊化編程的方法”,文中的講解內容簡單清晰,易于學習與理解,下面請大家跟著小編的思路慢慢深入,一起來研究和學習“Java9新特性Module模塊化編程的方法”吧!
在Java 9版本中Java 語言引入了一個非常重要的概念:模塊(module)。如果對javascript代碼模塊化管理比較熟悉的小伙伴,看到Java 9的模塊化管理,應該有似曾相識的感覺。
與Java 中的package有些類似,module引入了Java代碼分組的另一個級別。每個這樣的分組(module)都包含許多子package包。通過在一個模塊的源代碼文件package的根部,添加文件module-info.java來聲明該文件夾及其子文件夾為一個模塊。該文件語法如下:
module xxx.yyy{ .... }
其中xxx.yyy是模塊module聲明的名稱,不是package名稱。
文件module-info.java可以指定該模塊下面的哪些package對外可見、可訪問。通過一個新的關鍵字exports
來實現該功能。
module xxx.yyy{ exports com.zimug.java9; }
com.zimug.java9
代表一個package。
需要注意的是:即使給定package包中的類是public的,如果未通過’exports’顯式導出其程序包,則它們在模塊外部也是不可見的(在編譯時和運行時都是如此)。
如果另一個模塊想要使用被導出的package包中的類,可以用requires
關鍵字在其module-info.java文件中來導入(讀取)目標模塊的package包。
module def.stu{ requires xxx.yyy;}
在筆者看來,Java 9引入module 模塊化管理系統,更多的是從安全性的角度考慮。Java 代碼中90%以上的漏洞都是由反射和訪問權限控制粒度不足引起的,Java 9的模塊化系統正好能解決這個問題。Java 9 module提供另一個級別的Java 代碼可見性、可訪問性的控制。
比如說:我們都知道當一個class被修飾為private的時候,意味著這個類是內部類。對于頂級類(外部類)來說,只有兩種修飾符:public和默認(default)。這也就意味著一個問題,有些public class我們本來是打算在jar包定義的范圍內使用的,但是結果卻是任何引入了這個jar的項目都可以使用這個jar里面所有的public class代碼。
也就是我們的原意是在有限范圍內提供公開訪問,結果卻是無限制的對外公開。在引入Java 9模塊化之后,可以實現有限范圍內的代碼public訪問權限,將代碼公開區分為:模塊外部有限范圍的公開訪問和模塊內部的公開訪問。
在此示例中,我將創建兩個模塊“ common.widget”和“ data.widget”,并將它們放置在單個文件夾“ modules-examples/src”下。文件“ module-info.java”將放置在每個模塊的根文件夾下。
文件及目錄格式如下:
D:\modules-example>tree /F /A \---src +---common.widget | | module-info.java | | | +---com | | \---zimug | | RendererSupport.java | | | \---org | \---jwidgets | SimpleRenderer.java | \---data.widget | module-info.java | \---com \---example Component.java
本代碼文件目錄:
modules-example/src/common.widget/org/jwidgets/SimpleRenderer.java。
這個package在后文中沒有被exports。
package org.jwidgets; public class SimpleRenderer { public void renderAsString(Object object) { System.out.println(object); } }
本代碼文件目錄:
modules-example/src/common.widget/com/zimug/RendererSupport.java。
這個package在后文中被exports了。
package com.zimug; import org.jwidgets.SimpleRenderer; public class RendererSupport { public void render(Object object) { new SimpleRenderer().renderAsString(object); } }
模塊導出,本代碼文件目錄:modules-example/src/common.widget/module-info.java。只導出com.zimug
包,沒有導出 org.jwidgets
包。導出的模塊名稱為common.widget
module common.widget{ exports com.zimug; }
模塊導入common.widget
,本代碼文件目錄:modules-example/src/data.widget/module-info.java
module data.widget { requires common.widget; }
使用導入模塊common.widget
中的package:com.zimug
。本代碼文件路徑:
modules-example/src/data.widget/com/example/Component.java
package com.example; import com.zimug.RendererSupport; public class Component { public static void main(String[] args) { RendererSupport support = new RendererSupport(); support.render("Test Object"); } }
正常編譯執行,結果如下:
Test Object
由于包“ org.jwidgets”尚未通過“ common.widget”模塊導出,因此另一個模塊“ data.widget”無法使用該package包下的類SimpleRenderer
。我們做一個反例,看看會發生什么:
package com.example; import org.jwidgets.SimpleRenderer; public class Component { public static void main(String[] args) { SimpleRenderer simpleRenderer = new SimpleRenderer(); simpleRenderer.renderAsString("Test Object"); } }
編譯報錯信息如下:
D:\modules-example\src\data.widget\com\example\Component.java:3: error: package org.jwidgets is not visible import org.jwidgets.SimpleRenderer; ^ (package org.jwidgets is declared in module common.widget, which does not export it) 1 error
正如我們所看到的,未被exports的package下面的class即使是public的也不能被訪問。
感謝各位的閱讀,以上就是“Java9新特性Module模塊化編程的方法”的內容了,經過本文的學習后,相信大家對Java9新特性Module模塊化編程的方法這一問題有了更深刻的體會,具體使用情況還需要大家實踐驗證。這里是億速云,小編將為大家推送更多相關知識點的文章,歡迎關注!
免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。