真实的国产乱ⅩXXX66竹夫人,五月香六月婷婷激情综合,亚洲日本VA一区二区三区,亚洲精品一区二区三区麻豆

成都創(chuàng)新互聯(lián)網(wǎng)站制作重慶分公司

JDK12的新特性詳解

本篇內(nèi)容介紹了“JDK12的新特性詳解”的有關(guān)知識(shí),在實(shí)際案例的操作過(guò)程中,不少人都會(huì)遇到這樣的困境,接下來(lái)就讓小編帶領(lǐng)大家學(xué)習(xí)一下如何處理這些情況吧!希望大家仔細(xì)閱讀,能夠?qū)W有所成!

創(chuàng)新互聯(lián)建站服務(wù)項(xiàng)目包括郯城網(wǎng)站建設(shè)、郯城網(wǎng)站制作、郯城網(wǎng)頁(yè)制作以及郯城網(wǎng)絡(luò)營(yíng)銷(xiāo)策劃等。多年來(lái),我們專注于互聯(lián)網(wǎng)行業(yè),利用自身積累的技術(shù)優(yōu)勢(shì)、行業(yè)經(jīng)驗(yàn)、深度合作伙伴關(guān)系等,向廣大中小型企業(yè)、政府機(jī)構(gòu)等提供互聯(lián)網(wǎng)行業(yè)的解決方案,郯城網(wǎng)站推廣取得了明顯的社會(huì)效益與經(jīng)濟(jì)效益。目前,我們服務(wù)的客戶以成都為中心已經(jīng)輻射到郯城省份的部分城市,未來(lái)相信會(huì)繼續(xù)擴(kuò)大服務(wù)區(qū)域并繼續(xù)獲得客戶的支持與信任!

1、JDK12之Shenandoah低暫停時(shí)間垃圾收集器(實(shí)驗(yàn)性)

      定義:

    添加一個(gè)名為Shenandoah的新垃圾收集(GC)算法,通過(guò)與正在運(yùn)行的Java線程同時(shí)進(jìn)行疏散工作
來(lái)減少GC暫停時(shí)間。使用Shenandoah的暫停時(shí)間與堆大小無(wú)關(guān),這意味著無(wú)論堆是200MB還是200GB,都
將具有相同的一致暫停時(shí)間。

      非目標(biāo):

    這不是一個(gè)統(tǒng)治所有人的GC。還有其他垃圾收集算法可以優(yōu)先考慮吞吐量或內(nèi)存占用而不是響應(yīng)性。
Shenandoah是適用于評(píng)估響應(yīng)性和可預(yù)測(cè)的短暫停頓的應(yīng)用程序的算法。目標(biāo)不是解決所有JVM暫停問(wèn)
題。由于GC之外的其他原因(例如安全時(shí)間點(diǎn)(TTSP)發(fā)布或監(jiān)控通脹)而暫停時(shí)間超出了此JEP的范圍。

      構(gòu)建和調(diào)用:

    作為實(shí)驗(yàn)性功能,Shenandoah將-XX:+UnlockExperimentalVMOptions在命令行中要求。Shenandoah構(gòu)建系統(tǒng)會(huì)自動(dòng)禁用不受
支持的配置。下游建設(shè)者可以選擇--with-jvm-features=-shenandoahgc在其他支持的平臺(tái)上禁用構(gòu)建Shenandoah。
要啟用/使用Shenandoah GC,需要以下JVM選項(xiàng):-XX:+UnlockExperimentalVMOptions -XX:+UseShenandoahGC
2、JDK12之Microbenchmark Suite

      定義:

    在JDK源代碼中添加一套基本的微基準(zhǔn)測(cè)試,使開(kāi)發(fā)人員可以輕松運(yùn)行現(xiàn)有的微基準(zhǔn)測(cè)試并創(chuàng)
建新的基準(zhǔn)測(cè)試。

      目標(biāo):

1、基于[Java Microbenchmark線束(JMH)] [1]
2、穩(wěn)定且經(jīng)過(guò)調(diào)整的基準(zhǔn)測(cè)試,針對(duì)持續(xù)性能測(cè)試
    2.1、在功能發(fā)布的功能完成里程碑之后,以及非功能版本之后的穩(wěn)定且不移動(dòng)的套件
    2.2、支持與先前JDK版本的適用測(cè)試比較
3、簡(jiǎn)單
    3.1 輕松添加新基準(zhǔn)
    3.2 在API和選項(xiàng)更改,不推薦使用或在開(kāi)發(fā)期間刪除時(shí),可以輕松更新測(cè)試
    3.3 易于構(gòu)建
    3.4 易于查找和運(yùn)行基準(zhǔn)
    3.5 支持JMH更新
    3.6 在套件中包含大約一百個(gè)基準(zhǔn)的初始集
3、JDK12之Switch表達(dá)式(預(yù)覽版)

      預(yù)覽功能,如果該jdk12的switch效果不好的話,會(huì)被下一版本jdk13直接移除該功能,并不是之后每個(gè)版本必須的。

      許多break使它不必要地冗長(zhǎng),如果忘記寫(xiě)break,則會(huì)產(chǎn)生意料之外的結(jié)果或者異常,所以針對(duì)于此jdk12在這里進(jìn)行了優(yōu)化升級(jí)。

      JDK12之前的版本:   

switch (day) {    case MONDAY:    case FRIDAY:    case SUNDAY:        System.out.println(6);        break;    case TUESDAY:        System.out.println(7);        break;    case THURSDAY:    case SATURDAY:        System.out.println(8);        break;    case WEDNESDAY:        System.out.println(9);        break;
}

      JDK12:我們建議引入一種新形式的開(kāi)關(guān)標(biāo)簽,寫(xiě)成“case L ->”表示如果標(biāo)簽匹配,則只執(zhí)行標(biāo)簽右側(cè)的代碼。

switch (day) {    case MONDAY, FRIDAY, SUNDAY -> System.out.println(6);    case TUESDAY                -> System.out.println(7);    case THURSDAY, SATURDAY     -> System.out.println(8);    case WEDNESDAY              -> System.out.println(9);
}

      許多Switch表達(dá)式,每個(gè)case都會(huì)賦值給一個(gè)變量或者執(zhí)行某種操作,如下是賦值給numLetters變量具體值。

      JDK12之前:

int numLetters;switch (day) {    case MONDAY:    case FRIDAY:    case SUNDAY:
        numLetters = 6;        break;    case TUESDAY:
        numLetters = 7;        break;    case THURSDAY:    case SATURDAY:
        numLetters = 8;        break;    case WEDNESDAY:
        numLetters = 9;        break;    default:        throw new IllegalStateException("Wat: " + day);
}

      JDK12:將此表達(dá)為一種陳述是迂回的,重復(fù)的,并且容易出錯(cuò)。意味著我們應(yīng)該計(jì)算numLetters每一天的價(jià)值。應(yīng)該可以直接說(shuō),使用更清晰,更安全Switch表達(dá)式

int numLetters = switch (day) {    case MONDAY, FRIDAY, SUNDAY -> 6;    case TUESDAY                -> 7;    case THURSDAY, SATURDAY     -> 8;    case WEDNESDAY              -> 9;
};

      如果將它用在方法上,則可以為:

static void howMany(int k) {    switch (k) {        case 1 -> System.out.println("one");        case 2 -> System.out.println("two");        case 3 -> System.out.println("many");
    }
}

      或者類(lèi)上,我想到的這個(gè)switch這個(gè)功能可以用在抽象工廠類(lèi)方面。

T result = switch (arg) {
    case L1 -> e1;
    case L2 -> e2;
    default -> e3;};
4、JDK12之JVM常量API

      摘要:

引入API來(lái)模擬關(guān)鍵類(lèi)文件和運(yùn)行時(shí)工件的名義描述,特別是可從常量池加載的常量。

      動(dòng)機(jī):

    每個(gè)Java類(lèi)文件都有一個(gè)常量池,用于存儲(chǔ)類(lèi)中字節(jié)碼指令的操作數(shù)。從廣義上講,常量池中的條目描述了運(yùn)行
時(shí)工件(如類(lèi)和方法)或簡(jiǎn)單值(如字符串和整數(shù))。所有這些條目都稱為可加載常量,因?yàn)樗鼈兛梢宰鳛閘dc指令的
操作數(shù)(“加載常量”)。
它們也可能出現(xiàn)在invokedynamic指令的bootstrap方法的靜態(tài)參數(shù)列表中。執(zhí)行一個(gè)ldc或invokedynamic指令
導(dǎo)致加載常數(shù)被解析成一個(gè)標(biāo)準(zhǔn)的Java類(lèi),如“活”的值Class,String或int。
    操作class文件的程序需要對(duì)字節(jié)碼指令進(jìn)行建模,并依次對(duì)可加載的常量進(jìn)行建模。但是,使用標(biāo)準(zhǔn)Java類(lèi)型
來(lái)模擬可加載常量是不合適的。
    描述字符串(CONSTANT_String_info條目)的可加載常量可能是可以接受的,因?yàn)樯伞皩?shí)時(shí)” String對(duì)象
很簡(jiǎn)單,但是對(duì)于描述類(lèi)(CONSTANT_Class_info條目)的可加載常量是有問(wèn)題的,因?yàn)楫a(chǎn)生“實(shí)時(shí)”ClassObject
依賴于類(lèi)加載的正確性和一致性。
    不幸的是,類(lèi)加載有許多環(huán)境依賴和失敗模式:所需的類(lèi)不存在或者請(qǐng)求者可能無(wú)法訪問(wèn); 類(lèi)加載的結(jié)果因上下文
而異; 裝載類(lèi)有副作用;有時(shí)類(lèi)加載可能根本不可能(例如當(dāng)所描述的類(lèi)尚不存在或者無(wú)法加載時(shí),如在編譯那些相同類(lèi)
或在jlink轉(zhuǎn)換期間)。
    因此,處理可加載常量的程序如果能夠以純粹的名義符號(hào)形式操作類(lèi)和方法,以及不太知名的工件(如方法句柄和動(dòng)
態(tài)計(jì)算常量),則會(huì)更簡(jiǎn)單:    1、字節(jié)碼解析和生成庫(kù)必須以符號(hào)形式描述類(lèi)和方法句柄。如果沒(méi)有標(biāo)準(zhǔn)機(jī)制,它們必須采用ad-hoc機(jī)制,無(wú)論是
ASM的描述符類(lèi)型Handle,還是字符串元組(方法所有者,方法名稱,方法描述符),或者這些機(jī)制的特殊(并且容易出
錯(cuò))編碼單個(gè)字符串。
    2、如果它們可以在符號(hào)域中工作而不是使用“實(shí)時(shí)”類(lèi)和方法句柄,invokedynamic那么通過(guò)旋轉(zhuǎn)字節(jié)碼(例如LambdaMetafactory)來(lái)操作的Bootstraps 將更簡(jiǎn)單。
    3、編譯器和脫機(jī)轉(zhuǎn)換器(例如jlink插件)需要描述無(wú)法加載到正在運(yùn)行的VM的類(lèi)的類(lèi)和成員。編譯器插件(例如注
釋處理器)同樣需要用符號(hào)術(shù)語(yǔ)來(lái)描述程序元素。
5、JDK12之一個(gè)AArch74端口,而不是兩個(gè)

      摘要:

arm64在保留32位ARM端口和64位aarch74端口的同時(shí),刪除與端口相關(guān)的所有源。

      動(dòng)機(jī):

刪除此端口將允許所有貢獻(xiàn)者將他們的精力集中在單個(gè)64位ARM實(shí)現(xiàn)上,并消除維護(hù)兩個(gè)端口所需的重復(fù)工作。
6、JDK12之默認(rèn)CDS檔案

      摘要:

在64位平臺(tái)上使用默認(rèn)類(lèi)列表增強(qiáng)JDK構(gòu)建過(guò)程以生成類(lèi)數(shù)據(jù)共享(CDS)歸檔。

      目標(biāo):

1、改善開(kāi)箱即用的啟動(dòng)時(shí)間
2、消除用戶運(yùn)行-Xshare:dump以從CDS中受益的需要
7、JDK12之G1的可流動(dòng)混合收集

      摘要:

如果G1混合集合可能超過(guò)暫停目標(biāo),則使其可以中止。

      動(dòng)機(jī):

    G1的目標(biāo)之一是滿足用戶提供的暫停時(shí)間目標(biāo)以暫停其收集暫停。G1使用高級(jí)分析引擎來(lái)選擇在集合期間
要完成的工作量(這部分基于應(yīng)用程序行為)。此選擇的結(jié)果是一組稱為集合集的區(qū)域。一旦確定了集合集并且
已經(jīng)開(kāi)始集合,則G1必須在不停止的情況下收集集合集的所有區(qū)域中的所有活動(dòng)對(duì)象。如果啟發(fā)式選擇過(guò)大的收
集,則此行為可導(dǎo)致G1超過(guò)暫停時(shí)間目標(biāo),例如,如果應(yīng)用程序的行為發(fā)生變化,以致啟發(fā)式工作在“陳舊”數(shù)據(jù)
上,則可能發(fā)生這種情況。特別是在混合集合期間可以觀察到這種情況,其中集合集通??梢园嗯f區(qū)域。
需要一種機(jī)制來(lái)檢測(cè)啟發(fā)式方法何時(shí)反復(fù)為集合選擇錯(cuò)誤的工作量,如果是,則讓G1逐步遞增地執(zhí)行收集工作,
其中集合可以在每個(gè)步驟之后中止。這種機(jī)制將允許G1更頻繁地滿足暫停時(shí)間目標(biāo)。
8、JDK12之從G1中立即返回未使用的已提交內(nèi)存

      摘要:

增強(qiáng)G1垃圾收集器,以便在空閑時(shí)自動(dòng)將Java堆內(nèi)存返回給操作系統(tǒng)。

      成功指標(biāo):

如果應(yīng)用程序活動(dòng)非常低,G1應(yīng)該在合理的時(shí)間段內(nèi)釋放未使用的Java堆內(nèi)存。

      動(dòng)機(jī):

    目前G1垃圾收集器可能無(wú)法及時(shí)將已提交的Java堆內(nèi)存返回給操作系統(tǒng)。G1僅在完整GC或并發(fā)周期內(nèi)
從Java堆返回內(nèi)存。由于G1很難完全避免完整的GC,并且只觸發(fā)基于Java堆占用和分配活動(dòng)的并發(fā)周期,
因此在許多情況下它不會(huì)返回Java堆內(nèi)存,除非在外部強(qiáng)制執(zhí)行此操作。
    在使用資源支付的容器環(huán)境中,這種行為特別不利。即使在VM由于不活動(dòng)而僅使用其分配的內(nèi)存資源的
一小部分的階段,G1也將保留所有Java堆。這導(dǎo)致客戶始終為所有資源付費(fèi),云提供商無(wú)法充分利用其硬件。
    如果VM能夠檢測(cè)到Java堆的利用率不足(“空閑”階段),并在此期間自動(dòng)減少其堆使用量,則兩者都
將受益。
    Shenandoah和OpenJ9的GenCon收集器已經(jīng)提供了類(lèi)似的功能。
9、核心庫(kù)java.lang中支持Unicode11

    JDK 12版本包括對(duì)Unicode 11.0.0的支持。在發(fā)布支持Unicode 10.0.0的JDK 11之后,Unicode 11.0.0引入了以下JDK 12中包含的新功能:

1、684個(gè)新角色
    1.1、66個(gè)表情符號(hào)字符
    1.2、Copyleft符號(hào)
    1.3、評(píng)級(jí)系統(tǒng)的半星
    1.4、額外的占星符號(hào)
    1.5、象棋中國(guó)象棋符號(hào)
2、11個(gè)新區(qū)塊
    2.1、格魯吉亞擴(kuò)展
    2.2、瑪雅數(shù)字
    2.3、印度Siyaq數(shù)字
    2.4、國(guó)際象棋符號(hào)
3、7個(gè)新腳本
    3.1、Hanifi Rohingya
    3.2、Old Sogdian
    3.3、Sogdian
    3.4、Dogra
    3.5、Gunjala Gondi
    3.6、Makasar
    3.7、Medefaidrin
10、核心庫(kù)java.text支持壓縮數(shù)字格式
    NumberFormat添加了對(duì)以緊湊形式格式化數(shù)字的支持。緊湊數(shù)字格式是指以簡(jiǎn)短或人類(lèi)可
讀形式表示的數(shù)字。例如,在en_US語(yǔ)言環(huán)境中,1000可以格式化為“1K”,1000000可以格式化
為“1M”,具體取決于指定的樣式NumberFormat.Style。緊湊數(shù)字格式由LDML的Compact Number格式規(guī)范定義。要獲取實(shí)例,請(qǐng)使用NumberFormat緊湊數(shù)字格式所給出的工廠方法之一。    例如:NumberFormat fmt = NumberFormat.getCompactNumberInstance(Locale.US, NumberFormat.Style.SHORT);String result = fmt.format(1000);     上面的例子導(dǎo)致“1K”。
12、安全庫(kù)java.security

      禁止并允許java.security.manager系統(tǒng)屬性的選項(xiàng) 

    新的“disallow”和“allow”令牌選項(xiàng)已添加到j(luò)ava.security.manager系統(tǒng)屬性中。
在JDK實(shí)現(xiàn)中,如果Java虛擬機(jī)以系統(tǒng)屬性java.security.manager設(shè)置為“disallow”開(kāi)始,
則該System.setSecurityManager方法不能用于設(shè)置安全管理器并將拋出
UnsupportedOperationException。“disallow”選項(xiàng)可以提高從未設(shè)置安全管理器的應(yīng)用程
序的運(yùn)行時(shí)性能。

      groupname選項(xiàng)添加到keytool密鑰對(duì)生成 

-groupname添加了一個(gè)新選項(xiàng),keytool -genkeypair以便用戶在生成密鑰對(duì)時(shí)可以指
定命名組。例如,keytool -genkeypair -keyalg EC -groupname secp384r1將使用
secp384r1曲線生成EC密鑰對(duì)。由于可能存在多個(gè)具有相同大小的曲線,因此使用該-groupname
選項(xiàng)優(yōu)先于該-keysize選項(xiàng)。

      新Java飛行記錄器(JFR)安全事件

略過(guò)...

      自定義PKCS12密鑰庫(kù)生成 

    添加了新的系統(tǒng)和安全屬性,使用戶能夠自定義PKCS#12密鑰庫(kù)的生成。這包括用于密鑰保護(hù),
證書(shū)保護(hù)和MacData的算法和參數(shù)??梢栽谖募摹癙KCS12 KeyStore屬性”部分中找到這些屬性的
詳細(xì)說(shuō)明和可能的值java.security。
13、安全庫(kù)javax.net.ssl

      ChaCha20和Poly1305 TLS密碼

    JSSE中添加了使用ChaCha20-Poly1305算法的新TLS密碼套件。默認(rèn)情況下啟用這些密碼套件。
TLS_CHACHA20_POLY1305_SHA256密碼套件適用于TLS 1.3。
14、安全庫(kù)/ org.ietf.jgss

      在krb5.conf中支持DNS_canonicalize_hostname

    該dns_canonicalize_hostname標(biāo)志中krb5.conf的配置文件現(xiàn)在是由JDK Kerberos實(shí)現(xiàn)支持。
設(shè)置為“true”時(shí),服務(wù)主體名稱中的短主機(jī)名將被規(guī)范化為完全限定的域名(如果可用)。否則,不執(zhí)行規(guī)
范化。默認(rèn)值是true”。這也是JDK 12之前的行為。
15、刪除項(xiàng)

      核心庫(kù)/ java.util.jar中,刪除java.util.ZipFile / Inflator / Deflator中的finalize方法 

    該finalize方法在java.util.ZipFile,java.util.Inflator和java.util.Deflator是在JDK9
棄用用于移除及其執(zhí)行了更新,是一個(gè)空操作。該finalize在方法java.util.ZipFile,java.util.Inflator
以及java.util.Deflator在此版本中被刪除。finalize應(yīng)修改為執(zhí)行清理而重寫(xiě)的子類(lèi),以使用備用清理機(jī)制并
刪除寫(xiě)finalize方法。
    finalize方法,去除將暴露Object.finalize到的子類(lèi)ZipFile,Deflater和Inflater。finalize由于
聲明的異常發(fā)生更改,可能會(huì)在覆蓋時(shí)發(fā)生編譯錯(cuò)誤。Object.finalize現(xiàn)在宣布投擲java.lang.Throwable。
以前,只有java.io.IOException宣布。

      核心庫(kù)/ java.io,從FileInputStream和FileOutputStream中刪除finalize方法 

    該finalize方法FileInputStream和FileOutputStream被棄用去除JDK 9.他們已經(jīng)在此版本中被刪除。
所述java.lang.ref.Cleaner,自JDK9的主要機(jī)制已被實(shí)施,以關(guān)閉文件描述符不再?gòu)目傻竭_(dá)的FileInputStream和FileOutputStream。關(guān)閉文件的推薦方法是顯式調(diào)用close或使用try-with-resources。

      工具/ javac的刪除javac支持6 / 1.6源,目標(biāo)和發(fā)布值 

javac的6/1.6的參數(shù)值的支持-source,-target以及--release標(biāo)志已被刪除。

“JDK12的新特性詳解”的內(nèi)容就介紹到這里了,感謝大家的閱讀。如果想了解更多行業(yè)相關(guān)的知識(shí)可以關(guān)注創(chuàng)新互聯(lián)網(wǎng)站,小編將為大家輸出更多高質(zhì)量的實(shí)用文章!


網(wǎng)站標(biāo)題:JDK12的新特性詳解
瀏覽路徑:http://weahome.cn/article/pjigei.html

其他資訊

在線咨詢

微信咨詢

電話咨詢

028-86922220(工作日)

18980820575(7×24)

提交需求

返回頂部