Java用相同的方法在一個(gè)類中實(shí)現(xiàn)兩個(gè)接口哪種接口方法被覆蓋?
如果一個(gè)類型實(shí)現(xiàn)兩個(gè)接口,并且每個(gè)接口interface定義一個(gè)具有相同簽名的方法,則實(shí)際上只有一個(gè)方法,并且它們是不可區(qū)分的。例如,如果這兩個(gè)方法的返回類型沖突,那么它將是編譯錯(cuò)誤。這是繼承,方法重寫(xiě),隱藏和聲明的一般規(guī)則,并且不僅適用于兩個(gè)繼承的interface方法之間的可能沖突,還適用于an interface和super class方法之間的沖突,甚至僅適用于泛型類型擦除引起的沖突。
相容性范例在下面的示例中,你有一個(gè)interface Gift具有present()方法(例如,贈(zèng)送禮物)的和interface Guest,還具有一種present()方法(例如,客人在場(chǎng)并且不在場(chǎng))。
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)行。
請(qǐng)注意,只有一個(gè) @Override 必要條件!!!。這是因?yàn)镚ift.present()和Guest.present()是“- @Override等效的”(JLS 8.4.2)。
因此,johnny只有一個(gè)執(zhí)行的present(),并不要緊,你如何對(duì)待johnny,無(wú)論是作為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的方法,但要遵循方法重寫(xiě)和隱藏的通常要求。由于它們是 @Override等效的,因此實(shí)際上只有一種方法可以實(shí)現(xiàn),因此沒(méi)有區(qū)別/選擇的地方。
編譯器不必標(biāo)識(shí)哪個(gè)方法用于哪個(gè)接口,因?yàn)橐坏┐_定@Override它們等效,它們就是相同的方法。
解決潛在的不兼容性可能是一項(xiàng)艱巨的任務(wù),但這是另一個(gè)問(wèn)題。
解決方法具有相同方法名稱和簽名的兩個(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. 我在centos容器里安裝docker,也就是在容器里安裝容器,報(bào)錯(cuò)了?2. 在windows下安裝docker Toolbox 啟動(dòng)Docker Quickstart Terminal 失敗!3. docker-compose中volumes的問(wèn)題4. docker不顯示端口映射呢?5. golang - 用IDE看docker源碼時(shí)的小問(wèn)題6. docker內(nèi)創(chuàng)建jenkins訪問(wèn)另一個(gè)容器下的服務(wù)器問(wèn)題7. 關(guān)docker hub上有些鏡像的tag被標(biāo)記““This image has vulnerabilities””8. javascript - 最近用echarts做統(tǒng)計(jì)圖時(shí)遇到兩個(gè)問(wèn)題!!9. javascript - 連續(xù)點(diǎn)擊觸發(fā)mouseleave事件10. mac里的docker如何命令行開(kāi)啟呢?

網(wǎng)公網(wǎng)安備