在Java 中,當一個類別實現多個定義具有相同名稱和方法的介面時,簽名,問題來了:哪個方法是重寫?
根據Java語言規格(JLS),編譯器會依照下列規則決定要重寫的方法:
如果來自多個介面的繼承方法具有相同的簽名,則它們被視為「覆蓋等效」(JLS 8.4.8.4)。因此,只需要實作一種方法即可。
範例:
public class Test實作A, B { <br> public static void main( String... args) throws Exception{ <p>}</p><p>@Override<br> public int f() { // 來自哪個介面A 或B</p><pre class="brush:php;toolbar:false">return 0;
}
}
}
}< ;/pre>
在這段程式碼中,類別Test 實作了介面A 和B,它們都有一個方法命名為 f() 具有相同的簽章。由於這些方法是重寫等效的,因此 Test.f() 重寫哪個介面的 f() 方法並不重要。只需要一種實現,編譯器不會區分兩個介面。
這種行為擴展到繼承和方法隱藏。如果介面方法與超類別或另一個介面中的方法衝突,則衝突的方法必須重寫等效才能使程式碼有效。
相容性範例:
<br>公共介面禮物{ void 展示(); }<br>公用介面Guest { void Present(); }<pre class="brush:php;toolbar:false">System.out.println("Heeeereee's Johnny!!!");公用類別Presentable 實作Gift、Guest {
@Override
public void Present() {
}
}> ;這裡,Gift和Guest都有一個present ()方法。 Presentable 類別實作這兩個介面並為present() 提供單一實作。編譯器認識到這些方法是重寫等效的,不需要單獨實作。
不相容性範例:
;<br>公用介面Gift { void Present(); }<br>公用介面Guest { boolean Present(); }<br>public class Presentable Implements Gift, Guest { //無法編譯!!! // 錯誤:Gift 和 Guest 類型不相容}
在這種情況下,present() 方法的回傳類型是不同的。根據 JLS 8.4.8.3,重寫方法必須具有相容的簽章和回傳類型。由於 Gift.present() 和 Guest.present() 沒有相容的回傳類型,因此程式碼無法編譯。
綜上所述,當實作具有相同方法簽章的多個介面時,編譯器會將要重寫的方法標識為與重寫等效的方法。這意味著只需要一個方法實現,無論哪個介面定義該方法。
以上是Java 如何處理具有相同方法簽章的多個介面?的詳細內容。更多資訊請關注PHP中文網其他相關文章!