新聞中心
這篇文章主要介紹“JDK1.8的新特性有什么”,在日常操作中,相信很多人在JDK1.8的新特性有什么問(wèn)題上存在疑惑,小編查閱了各式資料,整理出簡(jiǎn)單好用的操作方法,希望對(duì)大家解答”JDK1.8的新特性有什么”的疑惑有所幫助!接下來(lái),請(qǐng)跟著小編一起來(lái)學(xué)習(xí)吧!
10年積累的成都做網(wǎng)站、網(wǎng)站建設(shè)經(jīng)驗(yàn),可以快速應(yīng)對(duì)客戶(hù)對(duì)網(wǎng)站的新想法和需求。提供各種問(wèn)題對(duì)應(yīng)的解決方案。讓選擇我們的客戶(hù)得到更好、更有力的網(wǎng)絡(luò)服務(wù)。我雖然不認(rèn)識(shí)你,你也不認(rèn)識(shí)我。但先網(wǎng)站設(shè)計(jì)后付款的網(wǎng)站建設(shè)流程,更有新田免費(fèi)網(wǎng)站建設(shè)讓你可以放心的選擇與我們合作。
代碼更少、更簡(jiǎn)潔
之所以備受關(guān)注的最原因是,JDK1.8 所做的改變,在許多方面比 Java 歷史上任何一次改變都深遠(yuǎn)。而且好消息是,這些改變會(huì)讓你編起程來(lái)更容易,用不著再寫(xiě)類(lèi)似下面這種啰嗦的程序了。(對(duì) peopleList 中人的年齡進(jìn)行排序)
Collections.sort(peopleList, new Comparator() { public int compare(People o1, People o2) { if (o1.getAge() > o2.getAge()) { return 1; } else { return -1; } }});
而在 JDK1.8 里,你可以編寫(xiě)如下更為簡(jiǎn)潔的代碼:
Collections.sort(peopleList, Comparator.comparingInt(People::getAge));
自從接觸 JDK1.8 后,這樣類(lèi)似簡(jiǎn)潔的代碼你將會(huì)非常喜歡的。
更好的利用多核處理器
JDK1.8 對(duì)多核處理器有更好的處理:平時(shí)我們用的電腦或服務(wù)器的 CPU 都是多核的,但是,絕大多數(shù)現(xiàn)有的 Java 程序都只使用其中一個(gè)內(nèi)核,而其他的都是處于閑置狀態(tài)。
在 JDK1.8 之前,可能有人會(huì)告訴你,必須使用多線(xiàn)程才能使用多個(gè)內(nèi)核。問(wèn)題是,線(xiàn)程用起來(lái)比較難,也容易出現(xiàn)錯(cuò)誤。從 JDK 的版本演變來(lái)看,它一直致力于讓并發(fā)編程更容易、出錯(cuò)更少。JDK1.0 里有線(xiàn)程和鎖,甚至有一個(gè)內(nèi)存模型——這是當(dāng)時(shí)的最佳做法,但事實(shí)證明,不具備專(zhuān)門(mén)知識(shí)的項(xiàng)目團(tuán)隊(duì)很難可靠地使用這些基本模型。JDK1.5 添加了如線(xiàn)程池和并發(fā)集合。JDK1.7 添加了分支/合并(fork/join)框架,使得并行變得更實(shí)用,但仍然很困難。而 JDK1.8 中對(duì)并行有了一個(gè)更簡(jiǎn)單的新思路,但需要遵循一些規(guī)則。
JDK1.8 提供了一個(gè)新的 API(稱(chēng)為“流”,Stream),它支持許多處理數(shù)據(jù)的并行操作,其思路和在數(shù)據(jù)庫(kù)查詢(xún)語(yǔ)言中的思路類(lèi)似:用更高級(jí)的方式表達(dá)想要的東西,而由“實(shí)現(xiàn)”(在這里
是 Streams 庫(kù))來(lái)選擇最佳低級(jí)執(zhí)行機(jī)制。這樣就可以避免用 synchronized 編寫(xiě)代碼,這一代碼不僅容易出錯(cuò),而且在多核 CPU 上執(zhí)行所需的成本也比你想象的要高。
速度更快
如果你的開(kāi)發(fā)環(huán)境裝的就是 JDK1.8,那么你就已經(jīng)在無(wú)形中享用 JDK1.8 的新特性了。
JDK1.8 對(duì)于底層的數(shù)據(jù)結(jié)構(gòu)上做了些更新和改動(dòng),對(duì)垃圾回收機(jī)制(內(nèi)存結(jié)構(gòu))也做了一定的改變,以及對(duì)于并行/并行流,并行的操作能夠很容易的進(jìn)行使用,對(duì)并行做了一些擴(kuò)展和支持。
我們一起了解一下它是怎么讓底層的數(shù)據(jù)結(jié)構(gòu)“速度更快”呢?我們都知道底層數(shù)據(jù)結(jié)構(gòu)最核心的一個(gè)就是 HashMap,那么它對(duì) HashMap 做了怎樣的改動(dòng)呢?
原來(lái)的 HashMap 是怎樣的呢?(數(shù)組+鏈表)
1.8 之后的 HashMap 是怎樣的呢?(數(shù)組+鏈表+紅黑樹(shù))
當(dāng)鏈表長(zhǎng)度太長(zhǎng)(默認(rèn)超過(guò) 8)時(shí),鏈表就轉(zhuǎn)換為紅黑樹(shù)。紅黑樹(shù)的改進(jìn)解決了什么問(wèn)題呢?
HashMap 碰撞處理的優(yōu)化,針對(duì)超長(zhǎng)鏈的檢查,時(shí)間復(fù)雜度從 O(n)降到了 O(log2n)。
HashMap 的優(yōu)化,只是體現(xiàn) JDK1.8 速度更快的典型代表之一,其他優(yōu)化之處在此就不一一說(shuō)明。
總結(jié)
看了上面這幾點(diǎn),你應(yīng)該知道為什么要關(guān)注 JDK1.8 的原因了吧。因?yàn)樗o我們開(kāi)發(fā)、系統(tǒng)帶來(lái)前所未有的好處,在后續(xù)的使用中,你會(huì)發(fā)現(xiàn)它的種種優(yōu)點(diǎn)。
到此,關(guān)于“JDK1.8的新特性有什么”的學(xué)習(xí)就結(jié)束了,希望能夠解決大家的疑惑。理論與實(shí)踐的搭配能更好的幫助大家學(xué)習(xí),快去試試吧!若想繼續(xù)學(xué)習(xí)更多相關(guān)知識(shí),請(qǐng)繼續(xù)關(guān)注創(chuàng)新互聯(lián)網(wǎng)站,小編會(huì)繼續(xù)努力為大家?guī)?lái)更多實(shí)用的文章!
網(wǎng)頁(yè)名稱(chēng):JDK1.8的新特性有什么
文章起源:http://fisionsoft.com.cn/article/ighoig.html