執(zhí)行映射減少操作的通用方法。(Java-8)
您所提出的示例與Java 8無(wú)關(guān),與Java中泛型的工作原理無(wú)關(guān)。Function<T, Integer>function并將在編譯時(shí)Function<T, Double>function進(jìn)行類型擦除,并將其轉(zhuǎn)換為Function。方法重載的經(jīng)驗(yàn)法則是具有不同的數(shù)量,類型或參數(shù)順序。由于這兩種方法都將轉(zhuǎn)換為采用Function參數(shù),因此編譯器會(huì)抱怨它。
話雖如此,srborlongan已經(jīng)提供了一種解決該問(wèn)題的方法。該解決方案的問(wèn)題在于,您必須Test針對(duì)每種類型(整數(shù),雙精度等)上的每種類型的操作(加法,減法等)不斷修改類。另一種解決方案是使用methodoverriding而不是method overloading:
Test如下更改類:
public abstract class Test<I,O extends Number> { List<I> list = new ArrayList<>(); public O performOperation(Function<I,O> function) {return list.stream().map(function).reduce((a,b)->operation(a,b)).get(); } public void add(I i) {list.add(i); } public abstract O operation(O a,O b);}
創(chuàng)建一個(gè)子類Test將添加兩個(gè)Integer。
public class MapStringToIntAddtionoperation extends Test<String,Integer> { @Override public Integer operation(Integer a,Integer b) {return a+b; }}
然后,客戶代碼可以使用上述代碼,如下所示:
public static void main(String []args) { Test<String,Integer> test = new MapStringToIntAddtionoperation(); test.add('1'); test.add('2'); System.out.println(test.performOperation(Integer::parseInt));}
使用這種方法的優(yōu)點(diǎn)是您的Test班級(jí)符合該open-closed原則。要添加新的運(yùn)算(如乘法),您要做的就是添加的新子類Test和將兩個(gè)數(shù)字相乘override的operation方法。將其與Decorator模式結(jié)合使用,您甚至可以最小化必須創(chuàng)建的子類的數(shù)量。
此答案中的示例僅供參考。有很多改進(jìn)的領(lǐng)域(例如使Test功能接口代替抽象類)超出了問(wèn)題的范圍。
解決方法如何在Java 8中使用泛型參數(shù)重載Function?
public class Test<T> { List<T> list = new ArrayList<>(); public int sum(Function<T,Integer> function) {return list.stream().map(function).reduce(Integer::sum).get(); } public double sum(Function<T,Double> function) {return list.stream().map(function).reduce(Double::sum).get(); }}
錯(cuò)誤:java:名稱沖突:sum(java.util.function.Function)和sum(java.util.function.Function)具有相同的擦除
相關(guān)文章:
1. php多任務(wù)倒計(jì)時(shí)求助2. 數(shù)組排序,并把排序后的值存入到新數(shù)組中3. mysql 遠(yuǎn)程連接出錯(cuò)10060,我已經(jīng)設(shè)置了任意主機(jī)了。。。4. 網(wǎng)頁(yè)爬蟲(chóng) - python 爬取網(wǎng)站 并解析非json內(nèi)容5. 默認(rèn)輸出類型為json,如何輸出html6. python的正則怎么同時(shí)匹配兩個(gè)不同結(jié)果?7. mysql怎么表示兩個(gè)字段的差8. win10 python3.5 matplotlib使用報(bào)錯(cuò)9. PHP訂單派單系統(tǒng)10. MySQL的聯(lián)合查詢[union]有什么實(shí)際的用處
