您好,登錄后才能下訂單哦!
這篇文章主要講解了“如何理解lambda”,文中的講解內(nèi)容簡單清晰,易于學(xué)習(xí)與理解,下面請大家跟著小編的思路慢慢深入,一起來研究和學(xué)習(xí)“如何理解lambda”吧!
類型為接口,有且只有一個(gè)需要實(shí)現(xiàn)的方法,就可以使用一個(gè)表達(dá)式作為該接口的實(shí)現(xiàn)
java lambda有能力表達(dá)一個(gè)完整的方法簽名(帶返回值),但在開發(fā)中總是寫全lambda并不能達(dá)到簡化代碼的效果,因此開發(fā)中我們更愿意使用lambda簡化后的寫法。
package com.karmic.lambda; import java.util.function.Function; import java.util.function.Supplier; /** * @author karmic */ public class LambdaDemo { public static void main(String[] args) { //lambda完全體 Function<String, Integer> f0 = (Function<String, Integer>) (String s) -> { return Integer.parseInt(s); }; //只有一行省略 {} 和 return Function<String, Integer> f1 = (Function<String, Integer>) (String s) -> Integer.parseInt(s); //簡化返回類型 Function<String, Integer> f2 = (String s) -> Integer.parseInt(s); //簡化入?yún)㈩愋? Function<String, Integer> f3 = (s) -> Integer.parseInt(s); //單入?yún)⑹÷匀雲(yún)?) Function<String, Integer> f4 = s -> Integer.parseInt(s); //表達(dá)式調(diào)用的方法 簽名和返回值與接口一致時(shí) 使用::簡化表達(dá)式 Function<String, Integer> f5 = Integer::parseInt; //類::靜態(tài)方法 或 對象::對象方法 可以轉(zhuǎn)換成簽名相同的方法 Supplier<String> a1 = DemoBean::getA; Supplier<String> a2 = new DemoBean()::getB; //類::對象方法 可以轉(zhuǎn)換成簽名第一個(gè)入?yún)轭悓ο?其余簽名一致的接口 Function<DemoBean, String> bf = DemoBean::getB; } static class DemoBean { public static String getA() { return "A"; } public String getB() { return "B"; } } }
優(yōu)雅的繞過NullPointException
package com.karmic.lambda; import java.util.Optional; /** * @author karmic */ public class NullExceptionAvoid { public static void main(String[] args) { A a = new A(new B(null)); String s = Optional.of(a).map(A::getB).map(B::getC).map(C::getS).orElse(null); System.out.println(s); } static class A { B b; public A(B b) { this.b = b; } public B getB() { return b; } } static class B { C c; public B(C c) { this.c = c; } public C getC() { return c; } } static class C { String s; public C(String s) { this.s = s; } public String getS() { return s; } } }
放棄代碼執(zhí)行控制權(quán)
// Create bean instance. if (mbd.isSingleton()) { sharedInstance = getSingleton(beanName, () -> { try { // Spring源碼,createBean方法是否執(zhí)行的控制權(quán),由getSingleton控制 判斷bean是否已經(jīng)創(chuàng)建過,再?zèng)Q定是否調(diào)用createBean方法 return createBean(beanName, mbd, args); } catch (BeansException ex) { // Explicitly remove instance from singleton cache: It might have been put there // eagerly by the creation process, to allow for circular reference resolution. // Also remove any beans that received a temporary reference to the bean. destroySingleton(beanName); throw ex; } }); bean = getObjectForBeanInstance(sharedInstance, name, beanName, mbd); }
MR式數(shù)據(jù)處理
package com.karmic.lambda; import java.util.ArrayList; import java.util.Arrays; import java.util.List; import java.util.Map; import java.util.function.Function; import java.util.stream.Collectors; /** * @author karmic */ public class StreamWordCountDemo { public static void main(String[] args) { @SuppressWarnings("serial") List<String> list = new ArrayList<String>() { { add("hello world"); add("hello java"); add("hello python"); add("hello kotlin"); } }; Map<String, Long> map = list.stream().map(s -> s.split(" ")) .flatMap(Arrays::stream) .collect(Collectors.groupingBy(Function.identity(), Collectors.counting())); System.out.println(map); } }
感謝各位的閱讀,以上就是“如何理解lambda”的內(nèi)容了,經(jīng)過本文的學(xué)習(xí)后,相信大家對如何理解lambda這一問題有了更深刻的體會(huì),具體使用情況還需要大家實(shí)踐驗(yàn)證。這里是億速云,小編將為大家推送更多相關(guān)知識(shí)點(diǎn)的文章,歡迎關(guān)注!
免責(zé)聲明:本站發(fā)布的內(nèi)容(圖片、視頻和文字)以原創(chuàng)、轉(zhuǎn)載和分享為主,文章觀點(diǎn)不代表本網(wǎng)站立場,如果涉及侵權(quán)請聯(lián)系站長郵箱:is@yisu.com進(jìn)行舉報(bào),并提供相關(guān)證據(jù),一經(jīng)查實(shí),將立刻刪除涉嫌侵權(quán)內(nèi)容。