Java用相同的方法在一個(gè)類中實(shí)現(xiàn)兩個(gè)接口。哪種接口方法被覆蓋?
如果一個(gè)類型實(shí)現(xiàn)兩個(gè)接口,并且每個(gè)接口interface定義一個(gè)具有相同簽名的方法,則實(shí)際上只有一個(gè)方法,并且它們是不可區(qū)分的。例如,如果這兩個(gè)方法的返回類型沖突,那么它將是編譯錯(cuò)誤。這是繼承,方法重寫,隱藏和聲明的一般規(guī)則,并且不僅適用于兩個(gè)繼承的interface方法之間的可能沖突,還適用于an interface和super class方法之間的沖突,甚至僅適用于泛型類型擦除引起的沖突。
相容性范例在下面的示例中,你有一個(gè)interface Gift具有present()方法(例如,贈送禮物)的和interface Guest,還具有一種present()方法(例如,客人在場并且不在場)。
Presentable johnny既是Gift和Guest。
public class InterfaceTest { interface Gift { void present(); } interface Guest { void present(); } interface Presentable extends Gift, Guest { } public static void main(String[] args) {Presentable johnny = new Presentable() { @Override public void present() {System.out.println('Heeeereee’s Johnny!!!'); }};johnny.present(); // 'Heeeereee’s Johnny!!!'((Gift) johnny).present(); // 'Heeeereee’s Johnny!!!'((Guest) johnny).present(); // 'Heeeereee’s Johnny!!!'Gift johnnyAsgift = (Gift) johnny;johnnyAsgift.present(); // 'Heeeereee’s Johnny!!!'Guest johnnyAsGuest = (Guest) johnny;johnnyAsGuest.present(); // 'Heeeereee’s Johnny!!!' }}
上面的代碼片段將編譯并運(yùn)行。
請注意,只有一個(gè) @Override 必要條件!!!。這是因?yàn)镚ift.present()和Guest.present()是“- @Override等效的”(JLS 8.4.2)。
因此,johnny只有一個(gè)執(zhí)行的present(),并不要緊,你如何對待johnny,無論是作為Gift或作為Guest,只有一個(gè)調(diào)用方法。
不兼容示例這是兩個(gè)不@Override等效的繼承方法的示例:
public class InterfaceTest { interface Gift { void present(); } interface Guest { boolean present(); } interface Presentable extends Gift, Guest { } // DOES NOT COMPILE!!! // 'types InterfaceTest.Guest and InterfaceTest.Gift are incompatible; // both define present(), but with unrelated return types'}
這進(jìn)一步重申,從interface必須繼承成員必須遵守成員聲明的一般規(guī)則。下面我們就Gift和Guest定義present()不兼容的返回類型:一個(gè)void其他的boolean。由于不能同時(shí)使用an void present()和boolean present()in的原因,此示例導(dǎo)致編譯錯(cuò)誤。
摘要你可以繼承@Override-equivalent的方法,但要遵循方法重寫和隱藏的通常要求。由于它們是 @Override等效的,因此實(shí)際上只有一種方法可以實(shí)現(xiàn),因此沒有區(qū)別/選擇的地方。
編譯器不必標(biāo)識哪個(gè)方法用于哪個(gè)接口,因?yàn)橐坏┐_定@Override它們等效,它們就是相同的方法。
解決潛在的不兼容性可能是一項(xiàng)艱巨的任務(wù),但這是另一個(gè)問題。
解決方法具有相同方法名稱和簽名的兩個(gè)接口。但是由單個(gè)類實(shí)現(xiàn),那么編譯器將如何確定哪個(gè)方法用于哪個(gè)接口?
例如:
interface A{ int f();}interface B{ int f();}class Test implements A,B{ public static void main(String... args) throws Exception{ } @Override public int f() { // from which interface A or B return 0; }}
相關(guān)文章:
1. Span標(biāo)簽2. docker-machine添加一個(gè)已有的docker主機(jī)問題3. redis啟動有問題?4. 關(guān)docker hub上有些鏡像的tag被標(biāo)記““This image has vulnerabilities””5. docker-compose中volumes的問題6. android新手一枚,android使用httclient獲取服務(wù)器端數(shù)據(jù)失敗,但是用java工程運(yùn)行就可以成功獲取。7. javascript - ng-options 設(shè)置默認(rèn)選項(xiàng),不是設(shè)置第一個(gè)哦,看清楚了!8. angular.js使用$resource服務(wù)把數(shù)據(jù)存入mongodb的問題。9. java - Collections類里的swap函數(shù),源碼為什么要新定義一個(gè)final的List型變量l指向傳入的list?10. css - 求推薦適用于vue2的框架 像bootstrap這種類型的
