91超碰碰碰碰久久久久久综合_超碰av人澡人澡人澡人澡人掠_国产黄大片在线观看画质优化_txt小说免费全本

溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點擊 登錄注冊 即表示同意《億速云用戶服務條款》

JDK8新特性實例分析

發布時間:2022-03-22 10:36:25 來源:億速云 閱讀:285 作者:iii 欄目:web開發

這篇“JDK8新特性實例分析”文章的知識點大部分人都不太理解,所以小編給大家總結了以下內容,內容詳細,步驟清晰,具有一定的借鑒價值,希望大家閱讀完這篇文章能有所收獲,下面我們一起來看看這篇“JDK8新特性實例分析”文章吧。

  函數式編程

  面向對象強調“一切皆對象”,如果想要做事情,必須要找到對象來做。函數式編程思想強調“做什么”,而不是“怎么做”。

  普通的開啟線程

  //匿名內部類對象

  Runnabletask=newRunnable(){

  @Override

  publicvoidrun(){

  System.out.println("烏鴉坐飛機");

  }

  };

  newThread(task).start();

  更多java相關免費視頻教程:java在線教程

  函數式編程開啟線程

  newThread(()->System.out.println("龍卷風摧毀停車場")).start();

  前面的小括號:方法參數,沒有參數時就寫(),箭頭指向后面要做的事情,箭頭后面就好比是方法體大括號,代表具體要做的內容。

  Lambda表達式

  Lambda表達式,也可稱為閉包,它是推動Java8發布的最重要新特性。

  Lambda允許把函數作為一個方法的參數(函數作為參數傳遞進方法中)。使用Lambda表達式可以使代碼變的更加簡潔緊湊。

  三要素:參數、箭頭、代碼

  格式:(參數類型參數名稱)->{一些代碼}

  使用Lambda表達式的前提:必須要有接口并且接口中有且只有一個抽象方法

  演示:編寫一個Cook接口,接口中有一個makeFood()方法

  publicstaticvoidmain(String[]args){

  method(()->{

  System.out.println("閃刀啟動!");

  });

  }

  privatestaticvoidmethod(Cookcook){

  cook.makeFood();

  }

  Lambda表達式省略規則:

  參數類型可以省略。但是只能同時省略所有參數的類型,或者干脆都不省略如果參數有且僅有一個,那么小括號可以省略如果大括號內的語句有且僅有一個,那么無論有沒有返回值,return、大括號、分號都可以省略。

  publicstaticvoidmain(String[]args){

  method((a,b)->a+b);

  }

  privatestaticvoidmethod(Calculatorcalculator){

  intresult=calculator.sum(1234,9876);

  System.out.println(result);

  }

  在new一個接口時,也可以使用lambda表達式來代替匿名內部類

  Runnabletask=()->System.out.println("閃刀啟動!");

  newThread(task).start();

  函數式接口

  接口當中有且僅有一個抽象方法,叫做函數式接口。

  JDK8中新增了注解@FunctionalInterface,用于檢測一個接口是否為函數式接口。如果不是函數式接口,編譯時會報錯。@FunctionalInerface注解是可選的,就算不用這個注解,只要保證接口滿足函數式接口的定義要求,也一樣是函數式接口。

  @FunctionalInterface

  publicinterfaceMyInterface{

  voidmethod();

  }

  方法引用

  Printerprinter=(str)->System.out.println(str);這段代碼實際上可以簡寫。

  只要是可推導的,就是可引用的,因此傳參其實并沒有意義,因此這里其實可以使用方法引用來簡寫System.out::println

  從java8開始,引入了一個全新的運算符,方法引用符(兩個冒號連著寫),所在的表達式就是一個方法引用,方法引用和Lambda本質是完全一樣的,目的就是簡化Lambda表達式的寫法。

  Lambda的寫法:s->System.out.println(s)

  方法引用寫法:System.out::println

  兩種寫發完全等效

  publicstaticvoidmain(String[]args){

  method(System.out::println);

  }

  privatestaticvoidmethod(Printerprinter){

  printer.print("hello");

  }

  接口

  default方法

  接口本來是兩個抽象方法,現在需要變成三個抽象方法,這個時候它的實現類也需要實現新的方法。

  當實現類太多時,操作起來很麻煩,JDK之前是使用開閉設計模式:對擴展開放,對修改關閉。即:創建一個新的接口,繼承原有的接口,定義新的方法,但是這樣的話,原本的那些實現類并沒有新的方法,這時候可以使用接口默認方法。

  關鍵字使用default進行修飾,方法需要方法體。這樣的方法所有的子類會默認實現(不用自己寫),如果想要覆蓋重寫,也可以在實現類中覆蓋重寫

  /**

  *從java8開始,接口當中允許定義default默認方法

  *修飾符:publicdefault(public可以省略,default不能省略)

  */

  publicinterfaceMyInterface{

  voidmethod1();

  voidmethod2();

  defaultvoidmethodNew(){

  System.out.println("接口默認方法執行");

  }

  }

  注意:接口中的default方法相當于是一個新的關鍵字,和四種修飾符的“default”并非一個概念。

  活用default關鍵字,可以使程序達到“多繼承”的效果。

  static方法

  從java8開始,接口當中允許定義靜態方法,用法與一般類的靜態方法相同。

  publicinterfaceAnimal{

  voideat();

  staticAnimalgetAnimal(){

  returnnewCat();

  }

  }

  流式操作

  流式處理給開發者的第一感覺就是讓集合操作變得簡潔了許多,通常我們需要多行代碼才能完成的操作,借助于流式處理可以在一行中實現。

  比如我們希望對一個包含整數的集合中篩選出所有的偶數,并將其封裝成為一個新的List返回,那么在java8之前,我們需要通過如下代碼實現:

  對于一個nums的集合:

  List<Integer>evens=newArrayList<>();

  for(finalIntegernum:nums){

  if(num%2==0){

  evens.add(num);

  }

  }

  通過java8的流式處理,我們可以將代碼簡化為:

  List<Integer>evens=nums.stream().filter(num->num%2==0).collect(Collectors.toList());

  先簡單解釋一下上面這行語句的含義,stream()操作將集合轉換成一個流,filter()執行我們自定義的篩選處理,這里是通過lambda表達式篩選出所有偶數,最后我們通過collect()對結果進行封裝處理,并通過Collectors.toList()指定其封裝成為一個List集合返回。

  常用操作案例:

  //初始化list集合

  List<String>list=newArrayList<String>();

  list.add("測試數據1");

  list.add("測試數據2");

  list.add("測試數據3");

  list.add("測試數據12");

  //使用&lambda;表達式遍歷集合

  list.forEach(s->System.out.println(s));

  //結合Predicate使用和過濾條件篩選元素

  Predicate<String>contain1=n->n.contains("1");

  Predicate<String>contain2=n->n.contains("2");

  //根據條件遍歷集合

  list.stream().filter(contain1).forEach(n->System.out.println(n));

  list.stream().filter(s->contain1.test(s)).forEach(s->System.out.println(s));

  list.stream().filter(contain1.and(contain2)).forEach(n->System.out.println(n));

  list.stream().filter(contain1.or(contain2)).forEach(n->System.out.println(n));

  //將過濾后的元素重新放到一個集合中

  List<String>newList=list.stream().filter(contain1.and(contain2)).collect(Collectors.toList());

  集合中decimal求和

  BigDecimalsum=list

  .stream()

  .map(Person::getAmount)

  .reduce(BigDecimal::add)

  .get();

  //排序,也需要新的集合接收

  List<Student>resultList=newArrayList<Student>();

  resultList=list.stream().sorted(Comparator.comparing(Student::getAge)).collect(Collectors.toList())

以上就是關于“JDK8新特性實例分析”這篇文章的內容,相信大家都有了一定的了解,希望小編分享的內容對大家有幫助,若想了解更多相關的知識內容,請關注億速云行業資訊頻道。

向AI問一下細節

免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。

jdk
AI

朝阳县| 同仁县| 当阳市| 邯郸市| 新宁县| 毕节市| 辰溪县| 丹棱县| 德化县| 寿宁县| 六盘水市| 上饶县| 陕西省| 宜章县| 库车县| 黄梅县| 榆中县| 宜春市| 北海市| 澄迈县| 奈曼旗| 长乐市| 泗阳县| 济宁市| 商南县| 江川县| 思茅市| 临颍县| 珠海市| 六安市| 原平市| 肥乡县| 岳普湖县| 陵水| 胶南市| 南丰县| 凉山| 湖州市| 博湖县| 上林县| 托克托县|