1.行為參數化,就是一個方法接受多個不同的行為作為參數,並在內部使用它們,完成不同行為的能力
2.行為參數化可以讓程式碼個好的適應不斷變化的要求,減輕工作量
3.lambda表達式是這一應用更加簡便
4.掌握分析謂詞,定義出合適的接口和實現方法
public static class Apple{ private String color; private Integer weight; private String sm; public String getSm() { return sm; } public void setSm(String sm) { this.sm = sm; } public Apple(String color, int weight) { this.color = color; this.weight = weight; } @Override public String toString() { return "Apple{" + "color='" + color + '\'' +", weight=" + weight +", sm='" + sm + '\'' +'}'; } public String getColor() { return color; } public void setColor(String color) { this.color = color; } public Integer getWeight() { return weight; } public void setWeight(Integer weight) { this.weight = weight; } } //从列表中筛选出绿色的苹果 public static List<Apple> filterGreenApple(List<Apple>inventory){ List<Apple>result=new ArrayList<>(); for (Apple apple : inventory) { if ("green".equals(apple.getColor())) { result.add(apple); } } return result; } //从列表中根据参数筛选出绿色的苹果 public static List<Apple>filerAppleByColor(List<Apple>appleList,String color){ List<Apple> apples=new ArrayList<>(); for (Apple apple : appleList) { if (apple.getColor().equals(color)) { apples.add(apple); } } return apples; } //统一定义行为参数接口类,这个行为的主体是apple public interface ApplePredicate{ boolean test(Apple apple); } public interface PredicateFormat{ String accept(Apple apple); } //定义泛型类的行为参数接口类,这个行为的主体不在局限某一个实物 public interface AbstratPredicate<T>{ boolean test(T t); } //参数行为化多实现类写法,实现按重量和颜色挑选苹果 public static class filterGreenWeightApple implements ApplePredicate{ @Override public boolean test(Apple apple) { return apple.getColor().equals("green")&&apple.getWeight()>100; } } public static class filteFannyApple implements PredicateFormat{ @Override public String accept(Apple apple) { String ss= apple.getWeight()>100? "light":"heavy"; return "A"+ ss+apple.getColor()+"Apple"; } } public static List<Apple>filterApplePredicate(List<Apple> appleList,ApplePredicate p){ List<Apple> apples=new ArrayList<>(); for (Apple apple : appleList) { if (p.test(apple)) { apples.add(apple); } } return apples; } public static List<Apple>filterFannyApple(List<Apple>appleList,PredicateFormat p){ List<Apple>apples=new ArrayList<>(); for (Apple apple : appleList) { apple.setSm(p.accept(apple)); apples.add(apple); } return apples; } //集成泛型接口的泛型类型方法 public static <T> List<T> filter(List<T>list,AbstratPredicate<T> pa){ List<T>lists=new ArrayList<>(); for (T t : list) { if (pa.test(t)) { lists.add(t); } } return lists; } //匿名类的笨重感 public static class MeaningOfThis{ public final int value=4; public void doIt(){ int value=6; Runnable r=new Runnable() { public final int value=5; @Override public void run() { int value=10; System.out.println(this.value); } }; r.run(); } } public static void main(String[] args) { List<Apple> appleList=Arrays.asList(new Apple("yellow",150),new Apple("green",150),new Apple("green",100)); //过滤绿色的苹果 List<Apple>result=filterGreenApple(appleList); result.stream().forEach((Apple a)->System.out.println(a)); //根据颜色参数过滤苹果 List<Apple>colorResult=filerAppleByColor(appleList,"yellow"); colorResult.stream().forEach(c->System.out.println(c)); //参数行为化多实现类写法,实现按重量和颜色挑选苹果 List<Apple>colorWeightApple=filterApplePredicate(appleList,new filterGreenWeightApple() ); colorWeightApple.stream().forEach(cw->System.out.println(cw)); List<Apple>fannyApple=filterFannyApple(appleList,new filteFannyApple()); fannyApple.stream().forEach(f->System.out.println(f)); System.out.println("-----------------------------"); //参数行为化匿名类实现 List<Apple>niming=filterApplePredicate(appleList, new ApplePredicate() { @Override public boolean test(Apple apple) { return apple.getColor().equals("green"); } }); niming.stream().forEach(n->System.out.println(n)); //匿名类的笨重感 MeaningOfThis mo=new MeaningOfThis(); mo.doIt(); //lambda表达式改写 System.out.println("-------我是lambda---------"); List<Apple>lamApples=filterApplePredicate(appleList,(Apple a)->a.getWeight()>100); lamApples.stream().forEach(la->System.out.println(la)); System.out.println("---------------"); List<Apple>lamApples1= filterFannyApple(appleList,(Apple a)->{ String ss=a.getWeight()>100?"lighter":"heavyer"; return "A"+ss+a.getColor()+"Apple"; }); lamApples1.sort((Apple a,Apple a1)->{ if (!a1.getWeight().equals(a.getWeight())) { return a1.getWeight().compareTo(a.getWeight()); }else { return a1.getColor().compareTo(a.getColor()); } }); lamApples1.stream().forEach(la1->System.out.println(la1)); //集成泛型接口的泛型类型方法 List<Integer>nums= Arrays.asList(1,2,3,4,5,6); List<Integer>numlist=filter(nums,(Integer i)->i%2==0); numlist.sort((Integer a,Integer a1)->a.compareTo(a1)); numlist.stream().forEach(i->System.out.println(i)); //自带的排序行为参数化的排序 Thread t=new Thread(()->System.out.println(new Apple("red",100))); t.start(); }
以上是淺談JAVA8中行為參數化的演變過程的詳細內容。更多資訊請關注PHP中文網其他相關文章!

Java如何緩解平台特定的問題? Java通過JVM和標準庫來實現平台無關性。 1)使用字節碼和JVM抽像操作系統差異;2)標準庫提供跨平台API,如Paths類處理文件路徑,Charset類處理字符編碼;3)實際項目中使用配置文件和多平台測試來優化和調試。

java'splatformentenceenhancesenhancesmicroservicesharchitecture byferingDeploymentFlexible,一致性,可伸縮性和便攜性。 1)DeploymentFlexibilityAllowsibilityAllowsOllowsOllowSorlowsOllowsOllowsOllowSeStorunonAnyPlatformwithajvM.2)penterencyCrossServAccAcrossServAcrossServiCessImplifififiesDeevelopmentandeDe

GraalVM通過三種方式增強了Java的平台獨立性:1.跨語言互操作,允許Java與其他語言無縫互操作;2.獨立的運行時環境,通過GraalVMNativeImage將Java程序編譯成本地可執行文件;3.性能優化,Graal編譯器生成高效的機器碼,提升Java程序的性能和一致性。

效率testjavaapplicationsforplatformcompatibility oftheSesteps:1)setUpautomatedTestingTestingActingAcrossMultPlatFormSusingCitoolSlikeSlikeJenkinSorgithUbactions.2)contuctualtemualtemalualTesteTESTENRETESTINGINREALHARTWARETOLEALHARDOELHARDOLEATOCATCHISSUSESUSEUSENINCIENVIRENTMENTS.3)schictcross.3)schoscross.3)

Java編譯器通過將源代碼轉換為平台無關的字節碼,實現了Java的平台獨立性,使得Java程序可以在任何安裝了JVM的操作系統上運行。

ByteCodeachievesPlatFormIndenceByByByByByByExecutedBoviratualMachine(VM),允許CodetorunonanyplatformwithTheApprepreprepvm.Forexample,Javabytecodecodecodecodecanrunonanydevicewithajvm

Java不能做到100%的平台獨立性,但其平台獨立性通過JVM和字節碼實現,確保代碼在不同平台上運行。具體實現包括:1.編譯成字節碼;2.JVM的解釋執行;3.標準庫的一致性。然而,JVM實現差異、操作系統和硬件差異以及第三方庫的兼容性可能影響其平台獨立性。

Java通過“一次編寫,到處運行”實現平台獨立性,提升代碼可維護性:1.代碼重用性高,減少重複開發;2.維護成本低,只需一處修改;3.團隊協作效率高,方便知識共享。


熱AI工具

Undresser.AI Undress
人工智慧驅動的應用程序,用於創建逼真的裸體照片

AI Clothes Remover
用於從照片中去除衣服的線上人工智慧工具。

Undress AI Tool
免費脫衣圖片

Clothoff.io
AI脫衣器

Video Face Swap
使用我們完全免費的人工智慧換臉工具,輕鬆在任何影片中換臉!

熱門文章

熱工具

VSCode Windows 64位元 下載
微軟推出的免費、功能強大的一款IDE編輯器

SecLists
SecLists是最終安全測試人員的伙伴。它是一個包含各種類型清單的集合,這些清單在安全評估過程中經常使用,而且都在一個地方。 SecLists透過方便地提供安全測試人員可能需要的所有列表,幫助提高安全測試的效率和生產力。清單類型包括使用者名稱、密碼、URL、模糊測試有效載荷、敏感資料模式、Web shell等等。測試人員只需將此儲存庫拉到新的測試機上,他就可以存取所需的每種類型的清單。

DVWA
Damn Vulnerable Web App (DVWA) 是一個PHP/MySQL的Web應用程序,非常容易受到攻擊。它的主要目標是成為安全專業人員在合法環境中測試自己的技能和工具的輔助工具,幫助Web開發人員更好地理解保護網路應用程式的過程,並幫助教師/學生在課堂環境中教授/學習Web應用程式安全性。 DVWA的目標是透過簡單直接的介面練習一些最常見的Web漏洞,難度各不相同。請注意,該軟體中

SublimeText3漢化版
中文版,非常好用

Safe Exam Browser
Safe Exam Browser是一個安全的瀏覽器環境,安全地進行線上考試。該軟體將任何電腦變成一個安全的工作站。它控制對任何實用工具的訪問,並防止學生使用未經授權的資源。