java11正式發佈了,讓java代碼更完美

Java11已經發布了,咱們今天聊聊你們還停留在哪一個版本呢?你們對於新版本的迅速的發佈有什麼想說的呢?
09 月 25 日,Oralce 正式發佈了 Java 11,這是據 Java 8 之後支持的首個長期版本。
咱們都知道,前面的幾個版本都不是長期支持的,然而,如今發佈這個最新的長期支持的版本仍是很是有意義的。
Java11也有許多的地方增長了新的功能,固然,也有一些功能刪除了。
下面這是java版本的發佈日期:
5954965-80173492f7a44cc1.jpg
5954965-80173492f7a44cc1.jpg
java11也從下面的這些地方更新(下面是官網的截圖)
搜狗截圖20180928195041.jpg
搜狗截圖20180928195041.jpg
搜狗截圖20180928195105.jpg
搜狗截圖20180928195105.jpg
由於Java11已經把Java9和Java10的一些功能也集成到了Java11中,因此,下面咱們從一些新的功能介紹一下。
Java 9 -11 引入的新語法和API
本地變量類型推斷
Java 10 就已經引入了新關鍵詞var,該關鍵詞能夠在聲明局部變量的時候替換類型信息。本地(local)是指方法內的變量聲明。
Java 10以前,你須要這樣聲明一個String對象。
String str="hello java 9";
在Java10裏頭可使用var替代String,表達式變成這樣:
var str="hello java 10";
用var聲明的變量仍然是靜態類型的。 不兼容的類型沒法從新分配給此類變量。 此代碼段沒法編譯:
var str="hello java 11"; str=11; //Incompatible types
當編譯器沒法推斷出正確的變量類型時,也不容許使用var。 如下全部代碼示例都會致使編譯器錯誤:
// Cannot infer type: var a; var nothing =null; var lambda=()->System.out.prinltn("Pity!"); var method=this::someNethod;
局部變量類型推斷能夠泛型。 在下一個示例中,Map 類型,能夠將其簡化爲單個var關鍵字,從而避免大量樣板代碼:
var myList = new ArrayList<Map<String,List<Integer>>>(); for(var current:myList) { //Current is infered to type:Map<String,List<Integer>> System.out.println(current); }
從Java 11開始,lambda參數也容許使用var關鍵字:
Predicate<String>predicate = (@Nullable var a)->true;
HTTP Client
Java 9開始引入HttpClient API來處理HTTP請求。 從Java 11開始,這個API正式進入標準庫包( java.net)。 讓咱們來探索一下咱們能夠用這個API作些什麼。
新的HttpClient能夠同步或異步使用。 同步請求會阻止當前線程。 BodyHandlers定義響應體的預期類型(例如,字符串,字節數組或文件):
var request = HttpRequest.newBuilder() .uri(URI.create("https://winterbe.com")) .GET() .build(); var client = HttpClient.newHttpClient(); HttpResponse<String> response = client.send(request, HttpResponse.BodyHandlers.ofString()); System.out.println(response.body());
也可使用異步來執行相同的請求。 調用sendAsync不會阻止當前線程,而是返回CompletableFuture來進行異步操做。
var request = HttpRequest.newBuilder() .uri(URI.create("https://winterbe.com")) .build(); var client = HttpClient.newHttpClient(); client.sendAsync(request, HttpResponse.BodyHandlers.ofString()) .thenApply(HttpResponse::body) .thenAccept(System.out::println);
咱們能夠省略.GET(),由於它是默認的請求方法。
下一個示例經過POST將數據發送到給定的URL。 與BodyHandler相似,您使用BodyPublishers定義做爲請求主體發送的數據類型,如字符串,字節數組,文件或輸入流:
var request = HttpRequest.newBuilder() .uri(URI.create("https://postman-echo.com/post")) .header("Content-Type", "text/plain") .POST(HttpRequest.BodyPublishers.ofString("Hi there!")) .build(); var client = HttpClient.newHttpClient(); var response = client.send(request, HttpResponse.BodyHandlers.ofString()); System.out.println(response.statusCode()); // 200
最後一個例子演示瞭如何經過BASIC-AUTH執行受權:
var request = HttpRequest.newBuilder() .uri(URI.create("https://postman-echo.com/basic-auth")) .build(); var client = HttpClient.newBuilder() .authenticator(new Authenticator() { @Override protected PasswordAuthentication getPasswordAuthentication() { return new PasswordAuthentication("postman", "password".toCharArray()); } }) .build(); var response = client.send(request, HttpResponse.BodyHandlers.ofString()); System.out.println(response.statusCode()); // 200
Collections
List,Set和Map等集合已經用新方法擴展。 List.of從給定的參數建立了一個新的不可變列表。 List.copyOf建立列表的不可變副本。
var list = List.of("A", "B", "C"); var copy = List.copyOf(list); System.out.println(list == copy); // true
由於list已是不可變的,因此實際上不須要實際建立list實例的副本,所以list和副本是相同的實例。 可是,若是你複製一個可變list,那麼複製確實會生成一個新實例,所以保證在改變原始list時沒有反作用:
var list = new ArrayList<String>(); var copy = List.copyOf(list); System.out.println(list == copy); // false
建立不可變map時,您沒必要本身建立map條目,而是將鍵和值做爲參數傳遞:
var map = Map.of("A", 1, "B", 2); System.out.println(map); // {B=2, A=1}
Java 11中的不可變集合仍然使用Collection API中的老接口。 可是,若是嘗試修改不可變集合,則會拋出java.lang.UnsupportedOperationException。 可喜的是,若是嘗試改變不可變集合,Intellij IDEA會經過發出警告。
Streams
Streams是在Java 8中引入的,Java 9增長了三個新方法。 單個參數構造方法:
Stream.ofNullable(null) .count() // 0
增長 takeWhile 和 dropWhile 方法,用於從stream中釋放元素:
Stream.of(1, 2, 3, 2, 1) .dropWhile(n -> n < 3) .collect(Collectors.toList()); // [3, 2, 1] Stream.of(1, 2, 3, 2, 1) .takeWhile(n -> n < 3) .collect(Collectors.toList()); // [1, 2]
若是對Stream不熟,能夠參考這篇文章[1]。
Optionals
Optionals提供了一些很是方便的功能,例如 您如今能夠簡單地將Optional轉換爲Stream,或者爲空Optinal提供另外一個Optional做爲備胎:
Optional.of("foo").orElseThrow(); // foo Optional.of("foo").stream().count(); // 1 Optional.ofNullable(null) .or(() -> Optional.of("fallback")) .get(); // fallback
Strings
Java11 給String增長了一些輔助方法來修剪或檢查空格等功能:
" ".isBlank(); // true " Foo Bar ".strip(); // "Foo Bar" " Foo Bar ".stripTrailing(); // " Foo Bar" " Foo Bar ".stripLeading(); // "Foo Bar " "Java".repeat(3); // "JavaJavaJava" "A\nB\nC".lines().count(); // 3
InputStreams
InputStream增長了transferTo方法,能夠用來將數據直接傳輸到 OutputStream:
var classLoader = ClassLoader.getSystemClassLoader(); var inputStream = classLoader.getResourceAsStream("myFile.txt"); var tempFile = File.createTempFile("myFileCopy", "txt"); try (var outputStream = new FileOutputStream(tempFile)) { inputStream.transferTo(outputStream); }
這些上面的新特性只是在前面幾個版本有的,或者一些比較以爲不錯的新特性,若是還想去了解更多的新特性能夠去官網查看(https://docs.oracle.com/en/java/javase/11/)
相關文章
相關標籤/搜索