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

歡迎訪問 生活随笔!

生活随笔

當前位置: 首頁 > 编程语言 > java >内容正文

java

java8方法引用符合_Java8 方法引用和构造方法引用

發布時間:2023/12/2 java 32 豆豆
生活随笔 收集整理的這篇文章主要介紹了 java8方法引用符合_Java8 方法引用和构造方法引用 小編覺得挺不錯的,現在分享給大家,幫大家做個參考.

如果不熟悉Java8新特性的小伙伴,初次看到函數式接口寫出的代碼可能會是一種懵逼的狀態,我是誰,我在哪,我可能學了假的Java,(???(???(???*),但是語言都是在進步的,就好比面向對象的語言Java也可以寫出優雅的函數式調用,學習的過程并不復雜,當你學會了Java8中函數式編程的新特性,你一定會對他愛不釋手的。下面介紹一下基于Lambda表達式簡寫的兩種引用。避免再次看到這種代碼時的尷尬😅。

方法引用

方法引用,一般包含下面三種寫法,傳統的寫法我們可能都是通過對象.去調用實例方法或使用類.調用靜態方法,但是學完方法引用后,就可以可以使用這三種方式去調用方法,但是要符合一定的規則。

對象::實例方法

/**

* 對象調用實例方法

*/

public static void objMethod(){

List list = new ArrayList<> ();

list.add(1);

list.add(2);

list.add(3);

list.forEach((i)->{

PrintStream out = System.out;

Consumer consumer = out::println;

consumer.accept(i);

});

list.forEach(System.out::println);

}

最常用的System.out.println

類::實例方法

/**

* 判斷兩個字符串是否相同

*

* @param str1

* @param str2

* @return

*/

public static boolean isEqual(String str1, String str2) {

BiPredicate b = (s1,s2)->s1.equals(str2); ①

BiPredicate bp = String::equals;

return bp.test(str1, str2);

}

類::靜態方法

/**

* 比較大小

* @param x

* @param y

* @return

*/

public static boolean compareValue(int x, int y){

Comparator compare = Integer::compare; ②

return compare.compare(x, y) > 0;

}

其實不管是哪一種調用方式都是有規律可循的,這里總結一下在使用Lambda表達式的過程中符合什么樣的規則才可以使用方法引用的模式去寫。

Lambda體中調用方法的參數列表與返回值類型,要與函數式接口中抽象方法的函數列表和返回值類型保持一致 Integer::compare ②

Lambda參數列表中的第一參數是實例方法的調用者,而第二個參數是實例方法的參數時 可以使用ClassName::method ①

構造方法引用

簡稱花式new對象,一個簡單的new對象也要寫的高端、大氣、上檔次😄,既可以掌握新知識,又可以ZB,趕緊學習吧。

ClassName::new

資源類:

public class Apple {

private String color;

private double weight;

public Apple(){

}

public Apple(String color) {

this.color = color;

}

public Apple(double weight) {

this.weight = weight;

}

public Apple(String color, double weight) {

this.color = color;

this.weight = weight;

}

public String getColor() {

return color;

}

public void setColor(String color) {

this.color = color;

}

public double getWeight() {

return weight;

}

public void setWeight(double weight) {

this.weight = weight;

}

@Override

public String toString() {

return "Apple{" +

"color='" + color + '\'' +

", weight=" + weight +

'}';

}

}

測試代碼:

public static void main(String[] args) {

//無參構造

//Supplier supplier = () -> new Apple(); Lambda表達式寫法

Supplier supplier = Apple::new;

Apple apple = supplier.get();

System.out.println("NoArgsConstructor: "+apple);

//有參構造

//Function function = (x) -> new Apple(x); Lambda表達式寫法

// 構造引用

Function function = Apple::new;

Apple apply = function.apply(1.0);

System.out.println("OneArgsConstructor: "+apply);

BiFunction bf = Apple::new;

Apple bi = bf.apply("Red", 2.0);

System.out.println("TwoArgsConstructor: "+bi);

}

輸出結果:

NoArgsConstructor: Apple{color='null', weight=0.0}

OneArgsConstructor: Apple{color='null', weight=1.0}

TwoArgsConstructor: Apple{color='Red', weight=2.0}

當構造方法無參時使用Supplier,有一個參數時使用Function,兩個參數時使用BiFunction。這里很容易得出一個規律,當使用構造方法引用時,函數式接口的參數列表需要和構造方法的參數列表保持一致。

我們也可以用這些函數式接口改寫傳統的創建數組的方式,初始化一個指定長度的數組,比如

Function fun = String[]::new;

String[] strArr = fun.apply(10);

也可以這樣寫:

public static T[] initArray(int num, Function function){

return function.apply(num);

}

調用:

Apple[] strings = initArray(10, x -> new Apple[x]);

System.out.println(strings.length);

疑惑?

根據傳入的參數返回指定的對象數組引用,不過這樣還不如直接創建。不知道讀者有沒有考慮這里為什么不可以用一個泛型來new,那樣就可以創建一個通用數組引用,但是Java中的泛型是偽泛型,在編譯器就會進行泛型擦除,所以不能通過new關鍵字來創建一個泛型對象,具體內容可以在查閱其他資料了解泛型以及泛型擦除的原理,這里不做深究。如果有其他寫法,期待你的回復。

總結

以上是生活随笔為你收集整理的java8方法引用符合_Java8 方法引用和构造方法引用的全部內容,希望文章能夠幫你解決所遇到的問題。

如果覺得生活随笔網站內容還不錯,歡迎將生活随笔推薦給好友。