java8新特性之方法引用示例代碼
簡介
方法引用是java8的新特性之一, 可以直接引用已有Java類或對象的方法或構造器。方法引用與lambda表達式結合使用,可以進一步簡化代碼。
方法引用的使用場景
我們用Lambda表達式來實現匿名方法。但有些情況下,我們用Lambda表達式僅僅是調用一些已經存在的方法,除了調用動作外,沒有其他任何多余的動作,在這種情況下,我們傾向于通過方法名來調用它,而Lambda表達式可以幫助我們實現這一要求,它使得Lambda在調用那些已經擁有方法名的方法的代碼更簡潔、更容易理解。方法引用可以理解為Lambda表達式的另外一種表現形式。
方法引用的分類
類型 | 語法 | 對應的Lambda表達式 |
---|---|---|
靜態(tài)方法引用 | 類名::staticMethod | (args) -> 類名.staticMethod(args) |
實例方法引用 | inst::instMethod | (args) -> inst.instMethod(args) |
對象方法引用 | 類名::instMethod | (inst,args) -> 類名.instMethod(args) |
構建方法引用 | 類名::new | (args) -> new 類名(args) |
示例代碼:
import lombok.AllArgsConstructor; import lombok.Data; /** * create gl **/ @Data @AllArgsConstructor public class User { private String name; private Integer age; private String sex; private Status status; public User(String name){ this.name=name; } public User(){} public User(String name, Integer age, String sex) { this.name = name; this.age = age; this.sex = sex; } public enum Status{ FREE, BUSY, VOCATION; } } import com.gl.java8test.User; import java.util.Comparator; import java.util.function.BiPredicate; import java.util.function.Consumer; import java.util.function.Function; import java.util.function.Supplier; /** * create gl * * 一。方法引用:若lambda 體中的內容 有方法已經實現,我們可以使用”方法引用“ * * 主要有三種語法格式 * * 1. 對象 :: 實例方法名 * 2. 類 :: 靜態(tài)方法名 * 3. 類 :: 實例方法名 * * 注意:方法體中的參數與返回類型 必須與該函數接口中的參數返回類型保持一致 * 第一個參數是實例的調用者,第二個參數是實例方法的參數時,可以這樣寫 ClassName::method * * * 二。 構造器引用 * 格式: ClassName::new * * 三. 數組引用 * 格式: Type[]::new **/ public class Test03 { //對象 :: 實例方法名 public static void test1(){ Consumer<String> consumer = System.out::println; consumer.accept("631235"); System.out.println("----------------------------"); User user=new User(); Supplier<String> stringSupplier = user::getName; stringSupplier.get(); } //類 :: 靜態(tài)方法名 public static void test2(){ Comparator<Integer> comparator = Integer::compare; } //類 :: 實例方法名 public static void test3(){ BiPredicate biP = (x,y) -> x.equals(y); // 下面這樣寫必須是 : 第一個參數是實例的調用者,第二個參數是實例方法的參數時,可以這樣寫 ClassName::method BiPredicate<String,String> biPredicate=String::equals; } //構造器引用 構造器的參數與返回類型 必須與該函數接口中的參數返回類型保持一致 public static void test4(){ // Supplier<User> userSupplier = () -> new User(); Supplier<User> userSupplier=User::new; User user = userSupplier.get(); System.out.println("----------------------------"); Function<String,User> function = User::new; User user1 = function.apply("sfsdf"); System.out.println(user1); } //數組引用 public static void test5(){ // Function<Integer,String[]> function = x -> new String[x]; Function<Integer,String[]> function = String[]::new; } public static void main(String[] args) { // test1(); test4(); } }
import com.gl.java8test.User; import java.util.Comparator; import java.util.function.BiPredicate; import java.util.function.Consumer; import java.util.function.Function; import java.util.function.Supplier; /** * create gl * * 一。方法引用:若lambda 體中的內容 有方法已經實現,我們可以使用”方法引用“ * * 主要有三種語法格式 * * 1. 對象 :: 實例方法名 * 2. 類 :: 靜態(tài)方法名 * 3. 類 :: 實例方法名 * * 注意:方法體中的參數與返回類型 必須與該函數接口中的參數返回類型保持一致 * 第一個參數是實例的調用者,第二個參數是實例方法的參數時,可以這樣寫 ClassName::method * * * 二。 構造器引用 * 格式: ClassName::new * * 三. 數組引用 * 格式: Type[]::new **/ public class Test03 { //對象 :: 實例方法名 public static void test1(){ Consumer<String> consumer = System.out::println; consumer.accept("631235"); System.out.println("----------------------------"); User user=new User(); Supplier<String> stringSupplier = user::getName; stringSupplier.get(); } //類 :: 靜態(tài)方法名 public static void test2(){ Comparator<Integer> comparator = Integer::compare; } //類 :: 實例方法名 public static void test3(){ BiPredicate biP = (x,y) -> x.equals(y); // 下面這樣寫必須是 : 第一個參數是實例的調用者,第二個參數是實例方法的參數時,可以這樣寫 ClassName::method BiPredicate<String,String> biPredicate=String::equals; } //構造器引用 構造器的參數與返回類型 必須與該函數接口中的參數返回類型保持一致 public static void test4(){ // Supplier<User> userSupplier = () -> new User(); Supplier<User> userSupplier=User::new; User user = userSupplier.get(); System.out.println("----------------------------"); Function<String,User> function = User::new; User user1 = function.apply("sfsdf"); System.out.println(user1); } //數組引用 public static void test5(){ // Function<Integer,String[]> function = x -> new String[x]; Function<Integer,String[]> function = String[]::new; } public static void main(String[] args) { // test1(); test4(); } }
總結
到此這篇關于java8新特性之方法引用的文章就介紹到這了,更多相關java8新特性方法引用內容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關文章希望大家以后多多支持腳本之家!
相關文章
Springboot文件上傳出現找不到指定系統(tǒng)路徑的解決
這篇文章主要介紹了Springboot文件上傳出現找不到指定系統(tǒng)路徑的解決方案,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教2021-08-08Spring Boot 2 Thymeleaf服務器端表單驗證實現詳解
這篇文章主要介紹了Spring Boot 2 Thymeleaf服務器端表單驗證實現詳解,文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友可以參考下2019-11-11SpringBoot使用@Scheduled實現定時任務的并行執(zhí)行
在SpringBoot中,如果使用@Scheduled注解來定義多個定時任務,默認情況下這些任務將會被安排在一個單線程的調度器中執(zhí)行,這意味著,這些任務將會串行執(zhí)行,而不是并行執(zhí)行,本文介紹了SpringBoot使用@Scheduled實現定時任務的并行執(zhí)行,需要的朋友可以參考下2024-06-06Spring Cloud OAuth2中/oauth/token的返回內容格式
Spring Cloud OAuth2 生成access token的請求/oauth/token的返回內容就需要自定義,本文就詳細介紹一下,感興趣的可以了解一下2021-07-07