Java11新特性概览
一、JShell(java9已經開始支持)
1、類似于python中的求值-打印循環(Read-Evaluaction-Print Loop),目的在與即時結果和反饋
2、java9引入了shell這個交互性工具,讓java也可以像腳本語言一樣來運行,可以從控制臺啟動jshell,在jshell中直接輸入表達式并查看其執行結果,當需要測試一個方法的運行效果或是快速的對表達式進行求值時,jshell都非常實用
3、除了表達式外,還可以創建java類和方法。jshell也有 基本的代碼完成,不在需要解釋必須有public static void main(String[] args)這句話
4、使用方式:
- 直接寫代碼片段即可調用
- 打開java文件使用
5、常見命令:
/help查看幫助二、Dynamic Class-File constants類文件新添的一種結構
1、java的類型文件格式將被拓展,支持一種新的常量池格式:CONSTANT Dynamic加載CONSTANT Dynamic會將創建委托給bootstrap方法
目標:其目標是降低開發新形式的可實現類文件約束帶來的成本和干擾
三、局部變量類型推斷(var關鍵字)
1、什么是局部變量類型推斷
局部變量類型推斷指的是java不在需要給變量定義具體的數據類型而是使用var來定義,編譯器能根據右邊表達式自動推斷類型,例如
var str = "java";就相當于 String str = "java"
注意:使用var語法必須進行初始化,因為var需要根據右側進行類型判斷
2、作用在lambda表達式上可以使用注解 (@NoneNull var a)->{ XXX }
四、java11新的API
1、集合的創建以更簡單的方式初始化
List list = new ArrayLiist<>();list.add("a");list.add("b");可直接改寫為:
List list = List.of("a","b");注意這里返回的list不是java.util下的list 不可繼續add元素
Set集合類似
2、Stream的改變
Stream.ofNullable(null);//創建流的時候可傳入null 防止出現空指針異常Stream.takeWhile(Predicate);//從流中獲取判定為真的元素,判定為假的時候 就停止判定Stream.dropWhile(Predicate);//從流中獲取為假的元素,判定為真丟棄,直到判定為假,停止判定Stream.iterate(1,t->tt*3+1);//無限流通過中間的判斷創建有限流3、String函數新增和改變
isBlank()判斷字符串是否為空白 包括空格回車 空字符串strip()去除字符串首尾空白 對比trim(),trim()只能去除unicode碼值小于32的字符 如漢字空格,所以strip()是對trim()的增強stripTrailing()去除尾部空白stripLeading()去除首部空白repeat(count);復制字符串count次lines().count();行數統計 lines返回一個Stream4、inputStream加強方法transferTo(os)直接把輸入流交給輸出流就可完成復制文件
五、標準java異步Http客戶端
java的http工具不在依賴第三方,java本身封裝的api
六、java執行源文件可不再編譯
注意:執行源文件中的第一個類(第一個類必須包括主方法),并且不可以使用其他源文件中的自定義類(不可跨文件操作)
七、垃圾收集器
1、新的Epsilon垃圾收集器
A NoOp Garbage Collector
JDK上對這個特性的描述是:開發一個處理內存分配但是不實現任何實際內存回收機制的GC,一旦可用堆內粗用戶,JVM就會退出
如果有System.gc()調用,實際上什么也不會發生(這種場景下和-XX:DisableExplicitGc效果一樣),因為沒有內存回收,這個實現可能會警告用戶強制GC是徒勞的
用法:-XX:+UnlockExperimentalVMOptions -XX:+UseEpsilonGC
使用原因:
提供完全被動的GC實現,具有有限的分配限制和盡可能低的延遲開銷,但代價是內存占用和內存吞吐量
java實現可廣泛選擇高度可配置的GC是,各種可用的收集器最終滿足不同的需求,即是它們的可配置性使他們的功能相交,有時更容易維護單獨的實現,而不是在現有GC實現上堆積另一個配置選項
主要用途:
性能測試(它可以幫助過濾掉GC引起的性能假象)
內存壓力測試(例如,知道測試用例 應該分配不超過1GB的內存,我們可以使用-Xxx1g -XX:+UseEpsilonGc,如果程序有問題那么就會崩潰)
非常短的job任務(對象這種任務,接受GC清理堆都是浪費空間)
VM接口測試:
Last-drop 延遲&吞吐改進
2、ZGC垃圾收集器
ZGC,A Scalable Low-Latency Garbage Collector(Experimental)
ZGC是jdk11最為矚目的特性,但是后面帶了Experimental,說明不建議用到生產環境
優點:
GC暫停時間不超過10ms
即能處理幾百兆的小堆也能處理幾個T的大堆
和G1相比應用吞吐能力不會下降超過15%
為未來GC功能和利用colord指針以及Load barriers優化奠定基礎 初始只支持64位系統
ZGC的設計目標是:支持TB級別內存容量,暫停時間低,對整個程序吞吐量影響小于15%,將來還可以擴展實現機制,以支持不少令人興奮的功能,例如多層堆(即熱對象置于DRAM和冷對象置于NVMe閃存)或壓縮堆
GC是java的主要優勢之一,然而當GC停頓太長,就會開始影響應用的響應時間,消除或減少GC停頓時常,Java將堆更廣泛的應用場景是一個更有吸引力的平臺,此外,現代系統中可用內存不斷增長,用戶和程序員之間希望JVM能夠以搞笑的方式充分利用這些內存,并且無須長時間的GC暫停時間
ZGC是一個并發,基于region壓縮型的垃圾收集器,只有root掃描階段會STW(stop the world),因此GC停頓時間不會隨著堆的增長和存貨對象的增長而變長
ZGC : avg 1.091ms max 1.681ms
G1 : avg 156.806ms max 543.846ms
用法: --XX:+UnlockExperimentalVMotions -XX:+UseZGC ,因為ZGC還處于實驗階段,所以需要通過jvm參數來解鎖這個特性
八、FightRecorder java黑匣子
Fight Recorder 以前是商業版的特性,在java11中開源出來,它可以導出事件到文件中,之后可以用Java Mission Conrol來分析,可以在應用啟動時配置 java -XX:StartFightRecording或者在應用程序啟動后使用jcmd來錄制比如
$ jcmd JFR.start$ jcmd JFR.dump filename=recording.jfr$ jcmd JFR.stop是oracle剛開源的強大特性,jfr性能最大開銷不超過1%
總結:雖然java11更新已經有些時間了,但是目前國內在用的公司并不多。java11后續也將是Oracle公司持續支持的一個版本,強大的G1垃圾收集器目前也處于適應性階段,相信當java11廣泛出線在中國市場的時候,Java行業會產生一些顛覆性的事件,筆者也并未深入研究,本文只是筆者通過學習做的一個簡單的概要,后續深入了解后會繼續補充本文。
總結
以上是生活随笔為你收集整理的Java11新特性概览的全部內容,希望文章能夠幫你解決所遇到的問題。
- 上一篇: 阿里软件测试工程师手把手教学:自动化脚本
- 下一篇: 图形学渲染管线