jdk17和jdk1.8區(qū)別
jdk17和jdk1.8區(qū)別
兩者的區(qū)別是所占內(nèi)存不同。jdk1.8中取消了**代,取而代之的是Metaspace,這個(gè)空間不占用jvm虛擬機(jī)的內(nèi)存,而是占用物理機(jī)的內(nèi)存。
JDK17限制抽象類的實(shí)現(xiàn),新增jdeps命令行,來分析類、目錄、jar包的類依賴層級(jí)關(guān)系。
jdk1.7和jdk1.8區(qū)別
在JDK1.7的新特性方面主要有下面幾方面的增強(qiáng):
1.jdk7語法上
2.NIO2的一些新特性
3百科.JDBC 4.1
4.并發(fā)工具增強(qiáng)
4.1.fork-join
5.Networking增強(qiáng)
6.Multithreaded Custom Class Loaders
JDK1.8的新特性
一、接口的默認(rèn)方法
二、Lambda表達(dá)式
三、函數(shù)式接口
四、方法與構(gòu)造函數(shù)引用
五、Lambda作用域
六、訪問局部變量
七、訪問對(duì)象字段與靜態(tài)變量
八、訪問接口的默認(rèn)方法
JDK 1.8 API包含了很多內(nèi)建的函數(shù)式接口,在老Java中常用到的比如Comparator或者Runnable接口,這些接口都增加了 FunctionalInterface注解以便能用在lambda上。
Java 8 API同樣還提供了很多全新的函數(shù)式接口來讓工作更加方便,有一些接口是來自Google Guava庫里的,即便你對(duì)這些很熟悉了,還是有必要看看這些是如何擴(kuò)展到lambda上使用的。
JDK1.6、JDK1.7、JDK1.8 內(nèi)存模型對(duì)比
如圖25-1 是 JDK 1.6、1.7、1.8 的內(nèi)存模型演變過程,其實(shí)這個(gè)內(nèi)存模型就是 JVM 運(yùn)行時(shí)數(shù)據(jù)區(qū)依照J(rèn)VM虛擬機(jī)規(guī)范的具體實(shí)現(xiàn)過程。 JDK 1.6:程序計(jì)數(shù)器、Java虛擬機(jī)棧、本地方法棧、堆、方法區(qū)[**代](字符串常量池、靜態(tài)變量、運(yùn)行時(shí)常量池、類常量池) JDK 1.7:程序計(jì)數(shù)器、Java虛擬機(jī)棧、本地方法棧、堆(字符串常量、靜態(tài)變量)、方法區(qū)[**代](運(yùn)行時(shí)常量池、類常量池) JDK 1.8:程序計(jì)數(shù)器、Java虛擬機(jī)棧、本地方法棧、堆(字符串常量)、元數(shù)據(jù)(靜態(tài)變量、運(yùn)行時(shí)常量池、類常量池)JDK 1.8 JVM 的內(nèi)存結(jié)構(gòu)主要由三大塊組成:堆內(nèi)存、元空間和棧,Java 堆是內(nèi)存空間占據(jù)**的一塊區(qū)域。
Java 堆,由年輕代和年老代組成,分別占據(jù)1/3和2/3。
年輕代又分為三部分, Eden 、 From Survivor 、 To Survivor ,占據(jù)比例為8:1:1,可調(diào)。 元空間從虛擬機(jī)Java堆中轉(zhuǎn)移到本地內(nèi)存,默認(rèn)情況下,元空間的大小僅受本地內(nèi)存的限制,說白了也就是以后不會(huì)因?yàn)?*代空間不夠而拋出OOM異常出現(xiàn)了。 jdk1.8以前版本的 class和JAR包數(shù)據(jù)存儲(chǔ)在 PermGen下面 ,PermGen 大小是固定的,而且項(xiàng)目之間無法共用,公有的 class,所以比較容易出現(xiàn)OOM異常。 升級(jí)JDK 1.8后,元空間配置參數(shù),-XX:MetaspaceSize=512M XX:MaxMetaspaceSize=1024M。
小技巧通過jps、jinfo查看元空間,如下: 通過jinfo查看默認(rèn)MetaspaceSize大?。s20M),MaxMetaspaceSize比較大。