日韩性视频-久久久蜜桃-www中文字幕-在线中文字幕av-亚洲欧美一区二区三区四区-撸久久-香蕉视频一区-久久无码精品丰满人妻-国产高潮av-激情福利社-日韩av网址大全-国产精品久久999-日本五十路在线-性欧美在线-久久99精品波多结衣一区-男女午夜免费视频-黑人极品ⅴideos精品欧美棵-人人妻人人澡人人爽精品欧美一区-日韩一区在线看-欧美a级在线免费观看

歡迎訪問 生活随笔!

生活随笔

當(dāng)前位置: 首頁 > 编程资源 > 编程问答 >内容正文

编程问答

java11正式发布了,让java代码更完美

發(fā)布時間:2025/3/20 编程问答 28 豆豆
生活随笔 收集整理的這篇文章主要介紹了 java11正式发布了,让java代码更完美 小編覺得挺不錯的,現(xiàn)在分享給大家,幫大家做個參考.

主題互動

Java11已經(jīng)發(fā)布了,我們今天聊聊大家還停留在哪個版本呢?大家對于新版本的迅速的發(fā)布有什么想說的呢

09 月 25 日,Oralce 正式發(fā)布了 Java 11,這是據(jù) Java 8 以后支持的首個長期版本。

我們都知道,前面的幾個版本都不是長期支持的,然而,現(xiàn)在發(fā)布這個最新的長期支持的版本還是非常有意義的。

Java11也有許多的地方增加了新的功能,當(dāng)然,也有一些功能刪除了。

下面這是java版本的發(fā)布日期:

5954965-80173492f7a44cc1.jpg

java11也從下面的這些地方更新(下面是官網(wǎng)的截圖)

搜狗截圖20180928195041.jpg 搜狗截圖20180928195105.jpg

因為Java11已經(jīng)把Java9和Java10的一些功能也集成到了Java11中,所以,下面我們從一些新的功能介紹一下。

Java 9 -11 引入的新語法和API

本地變量類型推斷

Java 10 就已經(jīng)引入了新關(guān)鍵詞var,該關(guān)鍵詞可以在聲明局部變量的時候替換類型信息。本地(local)是指方法內(nèi)的變量聲明。

Java 10之前,你需要這樣聲明一個String對象。

String?str="hello?java?9";

在Java10里頭可以使用var替代String,表達式變成這樣:

var?str="hello?java?10";

用var聲明的變量仍然是靜態(tài)類型的。 不兼容的類型無法重新分配給此類變量。 此代碼段無法編譯:

var?str="hello?java?11"; str=11;??//Incompatible?types

當(dāng)編譯器無法推斷出正確的變量類型時,也不允許使用var。 以下所有代碼示例都會導(dǎo)致編譯器錯誤:

//?Cannot??????infer?type: var?a; var?nothing?=null; var??lambda=()->System.out.prinltn("Pity!"); var?method=this::someNethod;

局部變量類型推斷可以泛型。 在下一個示例中,Map 類型,可以將其簡化為單個var關(guān)鍵字,從而避免大量樣板代碼:

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參數(shù)也允許使用var關(guān)鍵字:

Predicate<String>predicate?=?(@Nullable?var?a)->true;

HTTP Client

Java 9開始引入HttpClient API來處理HTTP請求。 從Java 11開始,這個API正式進入標(biāo)準(zhǔn)庫包(java.net)。 讓我們來探索一下我們可以用這個API做些什么。

新的HttpClient可以同步或異步使用。 同步請求會阻止當(dāng)前線程。 BodyHandlers定義響應(yīng)體的預(yù)期類型(例如,字符串,字節(jié)數(shù)組或文件):

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());

也可以使用異步來執(zhí)行相同的請求。 調(diào)用sendAsync不會阻止當(dāng)前線程,而是返回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將數(shù)據(jù)發(fā)送到給定的URL。 與BodyHandler類似,您使用BodyPublishers定義作為請求主體發(fā)送的數(shù)據(jù)類型,如字符串,字節(jié)數(shù)組,文件或輸入流:

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執(zhí)行授權(quán):

var?request?=?HttpRequest.newBuilder().uri(URI.create("https://postman-echo.com/basic-auth")).build(); var?client?=?HttpClient.newBuilder().authenticator(new?Authenticator()?{@Overrideprotected?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等集合已經(jīng)用新方法擴展。 List.of從給定的參數(shù)創(chuàng)建了一個新的不可變列表。 List.copyOf創(chuàng)建列表的不可變副本。

var?list?=?List.of("A",?"B",?"C"); var?copy?=?List.copyOf(list); System.out.println(list?==?copy);???//?true

因為list已經(jīng)是不可變的,所以實際上不需要實際創(chuàng)建list實例的副本,因此list和副本是相同的實例。 但是,如果你復(fù)制一個可變list,那么復(fù)制確實會生成一個新實例,因此保證在改變原始list時沒有副作用:

var?list?=?new?ArrayList<String>(); var?copy?=?List.copyOf(list); System.out.println(list?==?copy);???//?false

創(chuàng)建不可變map時,您不必自己創(chuàng)建map條目,而是將鍵和值作為參數(shù)傳遞:

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會通過發(fā)出警告。

Streams

Streams是在Java 8中引入的,Java 9增加了三個新方法。 單個參數(shù)構(gòu)造方法:

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提供了一些非常方便的功能,例如 您現(xiàn)在可以簡單地將Optional轉(zhuǎn)換為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方法,可以用來將數(shù)據(jù)直接傳輸?shù)?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); }

這些上面的新特性只是在前面幾個版本有的,或者一些比較覺得不錯的新特性,如果還想去了解更多的新特性可以去官網(wǎng)查看(https://docs.oracle.com/en/java/javase/11/)

或者查看下面的鏈接

  • [用于反應(yīng)式編程的Flow API]:https://community.oracle.com/docs/DOC-1006738
  • [Java模塊系統(tǒng)]:https://www.oracle.com/corporate/features/understanding-java-9-modules.html
  • [應(yīng)用程序類數(shù)據(jù)共享]:https://blog.codefx.org/java/application-class-data-sharing/
  • [動態(tài)類文件常量]:http://openjdk.java.net/jeps/309
  • [Java REPL(JShell)]:https://docs.oracle.com/javase/10/jshell/introduction-jshell.htm#JSHEL-GUID-630F27C8-1195-4989-9F6B-2C51D46F52C8
  • [飛行記錄器]:http://openjdk.java.net/jeps/328
  • [Unicode 10]:http://openjdk.java.net/jeps/327
  • [G1:完全并行垃圾收集器]:https://blog.idrsolutions.com/2018/04/java-10-improvements-to-garbage-collection-explained-in-5-minutes/
  • [ZGC:可擴展的低延遲垃圾收集器]:http://openjdk.java.net/jeps/333
  • [Epsilon:No-Op垃圾收集器]:http://openjdk.java.net/jeps/318
  • [棄用Nashorn JavaScript引擎]:http://openjdk.java.net/jeps/335

參考資料:

  • https://docs.oracle.com/en/java/javase/11/
  • http://openjdk.java.net/projects/jdk/11/
  • https://winterbe.com/posts/2018/09/24/java-11-tutorial/
  • https://www.oracle.com/technetwork/java/javase/11-relnote-issues-5012449.html#NewFeature

更多請掃描下方的二維碼關(guān)注我們的微信公眾號,每日推送新鮮資訊干貨!


關(guān)注微信公眾號“好好學(xué)java”,干貨每日更新!

總結(jié)

以上是生活随笔為你收集整理的java11正式发布了,让java代码更完美的全部內(nèi)容,希望文章能夠幫你解決所遇到的問題。

如果覺得生活随笔網(wǎng)站內(nèi)容還不錯,歡迎將生活随笔推薦給好友。