A. java8有哪些新特性
jdk1.8的新特性包括如下:
一、介面的默認方法與靜態方法,也就是介面中可以有實現方法
二、Lambda 表達式
三、函數式介面與靜態導入
四、Lambda 作用域
在lambda表達式中訪問外層作用域和老版本的匿名對象中的方式很相似。你可以直接訪問標記了final的外層局部變數,或者實例的欄位以及靜態變數。
五、訪問局部變數,等等其他新特性。
B. jdk1.6涓1.7鐨勫尯鍒錛
jdk1.7姣攋dk1.6娣誨姞浜嗕竴浜涙柊鐨勭壒鎬с
C. Java 7鏈変粈涔堟柊鐗規э紵
鍑犱箮鏂規柟闈㈤潰閮芥湁閲嶅ぇ鏇存柊錛屼婦鍑犱釜璇娉曚笂鐨勬柊鐗規э紝鍏朵粬鏂歸潰寤鴻浣犲幓鏌ユ壘鐩稿叧璧勬枡銆
1銆乻witch...case鏀鎸佸瓧絎︿覆銆
2銆佹暟瀛楀瓧闈㈤噺鏀硅繘錛屽姞鍏ヤ簩榪涘埗瀛楅潰閲忚〃紺猴細濡0b001001錛堝嶮榪涘埗鏁板瓧9錛夋垨0B001001錛
鏁板瓧瀛楅潰閲忎腑鍙浠ヤ嬌鐢ㄤ笅鍒掔嚎鍒嗗壊錛屼互浣塊暱鏁板瓧渚誇簬闃呰伙紝濡100000鍙浠ュ啓鎴100_000錛屽氨濂芥瘮鐜板疄鐢熸椿涓鍐欐垚100,000渚誇簬闃呰諱竴鏍楓
3銆佷紭鍖栧紓甯稿勭悊錛孴hroable綾誨炲姞addSuppressed鍜実etSuppressed鏂規硶錛岀敤鏉ヨ板綍琚鍏朵粬寮傚父鎶戝埗鑰屾棤娉曟e父鎶涘嚭鐨勫紓甯革紱
涓涓猚atch瀛愬彞鍙浠ユ崟鑾峰氫釜寮傚父錛屾瘡涓寮傚父涔嬮棿浣跨敤鈥渱鈥濆垎鍓詫紝濡俢atch (ClassNotFoundException cnfe | IOException ioe)錛
榪樻湁鍏朵粬鐨勪竴浜涗紭鍖栵紝濡傚紓甯哥被涓鍖呭惈鏇村氫俊鎮錛岀簿紜寮傚父鎶涘嚭絳夌瓑銆
4銆丣ava 7涔嬪墠閫氬父鍦╰ry閲屽壋寤鴻祫婧愶紝finally閲屽硅祫婧愯繘琛屽叧闂絳夋搷浣滐紝Java 7涓鍙浠ヤ嬌鐢╰ry-with-resources璇鍙ワ紝鑰屼笉闇瑕佸叧蹇冭祫婧愮殑鍏抽棴錛屽傗斺
try (InputStream input = new FileInputStream("D:/test1.txt");
OutputStream output = new FileOutputStream("D:/test2.txt")) {
byte[] buffer = new byte[1024];
int len = -1;
while ((len = input.read(buffer) != -1 ) {
output.write(buffer, 0, len);
}
}
灝嗚祫婧愮殑鍒涘緩鍐欏湪try鍚庣殑鎷鍙烽噷錛岃繖鏍峰氨涓嶉渶瑕佷嬌鐢╢inally璇鍙ユ潵淇濊瘉璧勬簮鐨勬g『鍏抽棴錛岀敱鉶氭嫙鏈鴻嚜鍔ㄥ畬鎴愶紝紼嬪簭鍛樺彧闇瑕佸叧蹇冧笟鍔¢昏緫鍗沖彲銆
5銆佸叧浜庡彉闀垮弬鏁扮殑浼樺寲錛屽炲姞浜咢SafeVarargs娉ㄨВ錛孞ava 7涔嬪墠鍦ㄤ嬌鐢ㄥ彲鍙橀暱鍙傛暟鐨勬柟娉曟椂錛屽傛灉鍙傛暟浼犻掔殑鏄涓嶅彲鍏蜂綋鍖栫殑綾誨瀷錛堝傛硾鍨嬬被鍨婰ist<String>錛変細浜х敓璀﹀憡淇℃伅錛屽傛灉甯屾湜榪涘埗璇ヨ﹀憡錛岄渶瑕佷嬌鐢ˊSuppressWarnings("unchecked")娉ㄨВ榪涜屽0鏄庯紝Java 7涓錛屽傛灉寮鍙戜漢鍛樼『淇℃煇涓浣跨敤浜嗗彲鍙橀暱鍙傛暟鐨勬柟娉曞湪涓庢硾鍨嬬被涓璧蜂嬌鐢ㄦ椂涓嶄細鍑虹幇綾誨瀷瀹夊叏闂棰橈紝灝卞彲浠ヤ嬌鐢ˊSafeVarargs娉ㄨВ鏉ュ0鏄庛傛敞鎰忚ユ敞瑙e彧鑳界敤浜庡彲鍙橀暱鍙傛暟鐨勬柟娉曟垨鑰呮瀯閫犳柟娉曪紝騫朵笖鏂規硶蹇呴』澹版槑涓簊tatic鎴杅inal銆
D. 上課要求jdk版本1.8.0而我的版本是jdk11,有什麼區別
jdk版本迭代都是根據上一代進行增添新功能。djk11在1.8版本上只是添加了少許新內容以適應現在互聯網技術節奏,除了新添加的內容,兩者沒有什麼影響。也就是,如果不用到新添加的內容,運行不受影響。但是需要知道,有哪些內容是新的。
JDK1.8的新特性:
一、介面的默認方法Java 8允許我們給介面添加一個非抽象的方法實現,只需要使用 default關鍵字即可,這個特徵又叫做擴展方法。
二、Lambda 表達式在Java 8 中你就沒必要使用這種傳統的匿名對象的方式了,Java 8提供了更簡潔的語法,lambda表達式:
Collections.sort(names, (String a, String b) -> {return b.compareTo(a);});
三、函數式介面Lambda表達式是如何在java的類型系統中表示的,每一個lambda表達式都對應一個類型,通常是介面類型。
而「函數式介面」是指僅僅只包含一個抽象方法的介面,每一個該類型的lambda表達式都會被匹配到這個抽象方法。因為默認方法不算抽象方法,所以也可以函數式介面添加默認方法。
四、方法與構造函數引用Java 8 允許你使用 :: 關鍵字來傳遞方法或者構造函數引用,上面的代碼展示了如何引用一個靜態方法,我們也可以引用一個對象的方法:
converter = something::startsWith;
String converted = converter.convert("Java");
System.out.println(converted);
五、Lambda 作用域在lambda表達式中訪問外層作用域和老版本的匿名對象中的方式很相似。你可以直接訪問標記了final的外層局部變數,或者實例的欄位以及靜態變數。
六、訪問局部變數可以直接在lambda表達式中訪問外層的局部變數:
七、訪問對象欄位與靜態變數 和本地變數不同的是,lambda內部對於實例的欄位以及靜態變數是即可讀又可寫。該行為和匿名對象是一致的:
八、訪問介面的默認方法JDK 1.8 API包含了很多內建的函數式介面,在老Java中常用到的比如Comparator或者Runnable介面,這些介面都增加了@FunctionalInterface註解以便能用在lambda上。
Java 8 API同樣還提供了很多全新的函數式介面來讓工作更加方便,有一些介面是來自Google Guava庫里的,即便你對這些很熟悉了,還是有必要看看這些是如何擴展到lambda上使用的。
(4)javajdk新特性擴展閱讀:
jdk11新特性:
1、字元串加強
// 判斷字元串是否為空白" ".isBlank(); // true// 去除首尾空格" Javastack ".strip(); // "Javastack"// 去除尾部空格 " Javastack ".stripTrailing()。
// 去除首部空格 " Javastack ".stripLeading(); // "Javastack "// 復制字元串"Java".repeat(3); // "JavaJavaJava"// 行數統計"A
B
C".lines().count(); // 3
2、HttClient Api
這是 Java 9 開始引入的一個處理 HTTP 請求的的孵化 HTTP Client API,該 API 支持同步和非同步,而在 Java 11 中已經為正式可用狀態,你可以在java.net包中找到這個 Api
3、用於 Lambda 參數的局部變數語法
用於 Lambda 參數的局部變數語法簡單來說就是支持類型推導:
var x = new A();for (var x : xs) { ... }try (var x = ...) { ... } catch ...
4、ZGC
從JDK 9開始,JDK使用G1作為默認的垃圾回收器。G1可以說是GC的一個里程碑,G1之前的GC回收,還是基於固定的內存區域,而G1採用了一種「細粒度」的內存管理策略,不在固定的區分內存區域屬於surviors、eden、old。
而我們不需要再去對於年輕代使用一種回收策略,老年代使用一種回收策略,取而代之的是一種整體的內存回收策略。
這種回收策略在我們當下cpu、內存、服務規模都越來越大的情況下提供了更好的表現,而這一代ZGC更是有了突破性的進步。
從原理上來理解,ZGC可以看做是G1之上更細粒度的內存管理策略。由於內存的不斷分配回收會產生大量的內存碎片空間,因此需要整理策略防止內存空間碎片化。
在整理期間需要將對於內存引用的線程邏輯暫停,這個過程被稱為"Stop the world"。只有當整理完成後,線程邏輯才可以繼續運行。
E. JDK7.0 與 JDK6.0 區別 及 JDK7的新特性
JDK7.0和JDK6.0有什麼區別?
jdk7是模塊化程序,模塊間的依賴性變小了.jdk的好多功能間有相互依賴性,導致一個配置不對,好多不能用.舉例來說:假設你正使用Logging API(java.util.logging)),Logging需要NIO和JMX,JMX需要JavaBeans, JNDI, RMI和CORBA,JNDI需要java.applet.Applet而且JavaBeans依賴AWT.
JDK7 新特性:
JSR203:JDK中會更多的IO API(「NIO.2」)訪問文件系統與之前的JDK中通過java.io.File訪問文件的方式不同,JDK7將通過java.nio.file包中的類完成。JDK7會使用java.nio.file.Path類來操作任何文件系統中的文件。(這里說的任何文件系統指的是可以使用任何文件存儲方式的文件系統)
示例:
Java7之前
File file = new File(「some_file」);
使用Java7
Path path = Paths.get(「some_file」);
在File類中加入了新的方法toPath(),可以方便的轉換File到Path
Path path = new File(「some_file」).toPath();
Socket通道綁定和配置在JDK7中面向通道的網路編程也得以更新!JDK7中可以直接綁定通道的socket和直接操作socket屬性。JDK7提供了平台socket屬性和指定實現的socket屬性。
JDK7加入了一個新的位元組通道類,SeekableByteChannel
NetworkChannel是面向網路通道編程模塊中的又一個新的超介面。利用它可以方便的綁定通道socket,並且方便設置和獲取socket的屬性。
MulticastChannel介面方便創建IP協議多播。多播實現直接綁定到本地的多播設備。
靈活的非同步I/O可以通過真正的非同步I/O,在不同的線程中運行數以萬計的流操作!JKD7提供了對文件和socket的非同步操作。一些JDK7中的新通道:
AsynchronousFileChannel:非同步文件通道可以完成對文件的非同步讀寫操作。
AsynchronouseSocketChannel:Socket中的一個簡單非同步通道,方法是非同步的並且支持超時。
:非同步的ServerSocket
AsynchronousDatagramChannel:基於數據包的非同步socket
JSR292:Java平台中的動態編程語言Da Vinci Machine項目(JSR292)的主旨是擴展JVM支持除Java以外的其它編程語言,尤其是對動態編程語言的支持。所支持的語言必須和Java一樣不收到歧視並共同存在。JSR334:Java語言的一些改進OpenJDK項目的創造(JSR334)的主旨是對Java語言進行一些小的改進來提高每天的Java開發人員的工作。這些改進包括:
Switch語句允許使用String類型
支持二進制常量和數字常量中可以使用下劃線
使用一個catch語言來處理多種異常類型
對通用類型實例的創建提供類型推理
Try-with-resources語句來自動關閉資源
JSR119:Java編譯器APIJSR199是在JDK6中加入的,主要用來提供調用Java編譯器的API。除了提供javac的命令行工具,JSR199提供Java編譯器到程序交互的能力。Java編譯器API要達到三個目標:
對編譯器和其它工具的調用
對結構化的編譯信息進行訪問
對文件輸入輸出定製化處理的能力
JSR206:Java XML處理的API (JAXP)JSR206即Java API for XML Processing(JAXP),是Java處理XML文檔的一個與實現無關,靈活的API。
JAXP1.3的主要特性包括:
DOM3
內建通過XML Schema進行文檔校驗的處理器
對XML Schema中的數據類型的實現,在javax.xml.datatype包中。
XSLTC,最快的轉換器,也是XSLT處理中的默認引擎。
提供對XInclude的實現。這將會方便我們使用文本和其它已有的XML來創建新的文檔,這樣可以對文檔片段進行重用。
JDK7中會包含JAXP1.3,這個是JAXP的最新實現。
綁定技術(JAXB)JSR222即Java Architecture for XML Binding(JAXB)。JAXB的目的是便於Java程序進行Java類到XML文檔的映射。
JAXB2的主要特性:
支持全部的W3C XML Schema特性。(JAXB1.0說明了對於W3C XML Schema中某些特性的不支持)
支持綁定Java到XML文檔,通過添加javax.xml.bind.annotation包來控制綁定。
大量減少了對於schema衍生出來的類。
通過JAXP1.3的校驗API來提供額外的校驗能力。
JDK7中將包括JAXB2.2
JSR224:基於XML的Web服務API(JAX-WS)JSR224即Java API for XML-based Web Services(JAX-WS),是一個基於Annotation標注的編程模型,主要針對Web Service應用和客戶端開發。
JAX-WS2的主要特性包括:
對JAXB2.1 API的支持(JSR222)
對Web Services Addressing 1.0的支持
EndpointReference(EPR)的API:創建(BindingProvider.getEndpointReference(),Endpoint.getEndpointReference(),MessageContext.getEndpointReference())
事務處理(使用JAXB2.1綁定W3C EPR到W3CEndpointReference類,使用JAXB Marshall/Unmarshall W3CendpointReference類)
提供友好的API來啟用和停止某些特性,例如MTOM特性和Addressing特性
JDK7將包含JAX-WS2.2
可插拔的Annotation處理APIJSR269即Pluggable Annotation-Processing API
從JDK5開始,Annotation標注就成了強大的機制用來標注我們的類、屬性和方法。通常Annotation標注是在創建階段或者運行階段進行處理的,並獲取語義結果。JSR269主要用來定義一套API,允許通過可插拔的API來進行標注處理器的創建。
規范包括一部分的API用來對Java編程語言進行構建,還有就對標注處理器聲明和控制運行的部分。
有了程序中的Annotation標注,就需要有標注處理器框架來反射程序的結構。
Annotation處理器會指定他們處理的標注並且更多的處理器可以合作運行。
標注處理器和程序結構的API可以在構建階段訪問。
小的改進java.util.Objects提供了一套9個靜態方法。其中兩個方法用來檢測當前對象是null還是非null。兩個方法用來提供生成toString()字元串同時支持null對象。兩個用來處理hash的方法。兩個方法用來處理equals。最後一個compare方法用來進行比較。Swing JLayer組件JXLayer是一個組件裝飾器,提供了用來裝飾多個組合組件的方式,並且可以捕獲所有滑鼠、鍵盤和FocusEvent的事件,並針對所有的XLayer子組件。這個組件只會對public swing的api起作用,對全局設置沒有作用,例如對EventQueue或者RepaintManager。(除了這些,Swing還將在JDK7中提供JXDatePicker和CSS方式樣式)並發和集合APIJSR166,並發和集合API提供了靈活的非同步處理,並發HashMap,傳輸隊列和輕量級的fork/join框架以及本地線程方式的偽隨機數生成器。類載入器體系結構類載入器已經升級到了可以在無等級類載入器拓撲中避免死鎖。JDK7中包含了一個對於多線程自定義類載入器的增強實現,名字為具有並行能力的類載入器。使用平行能力的類載入器載入class,會同步到類載入器和類名。Locale類的改進Java Locale避免由於小的變化導致數據丟失。除此,Locale應該提供更多的特性,例如IETF BCP 47和UTR 35(CLDR/LDML)。分離用戶Locale和用戶介面LocaleJDK7分離了UI語言的locale和格式化locale,這個已經在Vista之後的windows系統中實現了。嚴格的類文件檢測通過JavaSE6的規范,version51(SE7)的類文件和之後的版本必須通過類型檢測來檢驗。對於老的推理驗證VM不可以宕掉Elliptic-Curve
Cryptography (ECC)橢圓曲線加密
從JDK7開始,Java提供對標準的ECC演算法的靈活實現(基於橢圓曲線的公鑰加密演算法)Swing中的Nimbus外觀Nimbus是JDS(Java Desktop System)中的新外觀。這個也是Solaris11的GTK主題Java2D中的XRender PipelineJDK7中加入了基於X11 XRender擴展的Java2D圖形管道。這將提供更多的對於當前先進的GPUs訪問的功能。TLS1.2TLS (Transport Layer Security)是一個用在Internet上的數據傳輸安全協議,用來避免監聽、引誘和消息偽造。TLS的主要目的是提供兩個應用間通信的隱私和數據完整。TLS是RFC5246標准,在JDK7中提供1.2JDBC4.0/4.1JDBC4.1特性只在JDK7或者更高版本中存在。JDBC4.1隻是對JDBC4.0進行較小的改動。關於一些JDBC4.0/4.1的特性:
數據源—Derby包括了對於javax.sql.DataSource的新的實現
JDBC驅動自動載入—應用不必在通過Class.forName()方法來載入資料庫驅動了。取而代之的是DriverManager會根據應用請求連接的情況,自動查找到合適的JDBC驅動。
包裝—這是JDBC4.0中的新的概念,主要是通過這種機制可以讓應用獲取的廠商提供的標准JDBC對象實現,例如Connections,Statements和ResultSets。
Statement事件—連接池可以監聽Statement的關閉和錯誤時間。addStatementEventListener和removeStatementEventListener被加入到了javax.sql.PooledConnection
JDK7提供了JDBC4.1全部的支持
透明窗體和異形窗體為了6u10版本的圖形處理,JDK提供了透明效果的支持(簡單透明和像素透明)並且提供了對於異形窗體的支持(可以將窗體設置成任意形狀),輕重混合並且增強了AWT安全警告。透明效果和異形窗體是通過com.sun.awt.AWTUtilities類實現的。Unicode6.0Unicode6.0提供了諸如2.088字元集、對已經存在字元集的屬性改進、格式化改進以及新的屬性和數據文件。
JDK7已經更新到對Unicode6.0的支持。
要來關閉URLClassLoader的方法
對JMX代理和MBeans的改進
通過URLClassLoader,應用可以通過URL搜索路徑來載入類和資源。JKD7提供了close()新方法來幫助URLClassLoader清理資源。
這個改進來至於JRockit,可以方便連接平台。MBean伺服器可以通過防火牆提供一套MBeans,這些暴露了VM中的一些內部操作的信息
新的垃圾回收器JDK7提供了新的垃圾回收器,針對目前的CMS垃圾回收器,這將會讓垃圾回收器有更少的停頓時間和更高的語言效果。改進的JSRJSR901:Java Language Specification(JLS)Java語言計劃
JSR901包括了從第一版Java規范到現在為止的所有的變化、說明和補充。Java語言通過JLS規范。
對於JLS的改變通過JSR901進行管理
JDK7將會包括最新的JSR901
JSR924:JVM平台規范
JSR924目的是維護Java虛擬機規范的變化,其中第二版是為了J2SE1.5的。
Java SE API
JavaSE APIs保持著對例行維護和小范圍改進的加入計劃的記錄
延期到JDK8或者之後的規范
JSR294:Java語言和虛擬機對模塊編程技術的支持—當前JSR主要的目的是提供在編譯期和運行期的模塊編程支持
JSR308:對於Java類型的Annotation注釋—這將是對於當前注釋符號系統的擴展,將允許我們在類型中出現注釋符號。
JSR296:Swing應用框架—主旨是消除Swing編程中的模板代碼並且提供Swing程序更加簡單的結構。
模塊化—提供一個明確的、簡單的、低級別的模塊系統,主要目的是將JDK模塊化。
JSR TBD:Lambda項目—Lambda表達式(通俗的也稱為「閉包「)和對Java編程語言的保護方法
JSR TBD:對於集合支持的語言—常量表達式對於lists、sets和maps的迭代以及通過索引符號對lists和maps的訪問。
Swing JDatePicker組件—添加SwingLabs JXDatePicker組件到平台。