Java接口操作(繼承父類并實現(xiàn)多個接口)
/*
使用接口的時候,需要注意:
1. 接口是沒有靜態(tài)代碼塊或者構(gòu)造方法的。 2. 一個類的直接父類是唯一的,但是一個類可以同時實現(xiàn)多個接口。
格式:
public class MyInterfaceImpl implements MyInterfaceA, MyInterfaceB { // 覆蓋重寫所有抽象方法 }
3. 如果實現(xiàn)類所實現(xiàn)的多個接口當(dāng)中,存在重復(fù)的抽象方法,那么只需要覆蓋重寫一次即可。
A接口
package cn.itcast.day10.demo02; public interface MyInterfaceA { // 錯誤寫法!接口不能有靜態(tài)代碼塊 // static { // // } // 錯誤寫法!接口不能有構(gòu)造方法 // public MyInterfaceA() { // // } public abstract void methodA(); public abstract void methodAbs(); public default void methodDefault() { System.out.println("默認(rèn)方法AAA"); } }
B接口
package cn.itcast.day10.demo02; public interface MyInterfaceB { // 錯誤寫法!接口不能有靜態(tài)代碼塊 // static { // // } // 錯誤寫法!接口不能有構(gòu)造方法 // public MyInterfaceA() { // // } public abstract void methodB(); public abstract void methodAbs(); public default void methodDefault() { System.out.println("默認(rèn)方法BBB"); } }
實現(xiàn)類有多個接口
package cn.itcast.day10.demo02; public class MyInterfaceImpl /*extends Object*/ implements MyInterfaceA, MyInterfaceB { @Override public void methodA() { System.out.println("覆蓋重寫了A方法"); } @Override public void methodB() { System.out.println("覆蓋重寫了B方法"); } @Override public void methodAbs() { System.out.println("覆蓋重寫了AB接口都有的抽象方法"); } // A B 都有 覆蓋一次 @Override public void methodDefault() { System.out.println("對多個接口當(dāng)中沖突的默認(rèn)方法進(jìn)行了覆蓋重寫"); } }
只覆蓋重寫了一次。
4. 如果實現(xiàn)類沒有覆蓋重寫所有接口當(dāng)中的所有抽象方法,那么實現(xiàn)類就必須是一個抽象類。
package cn.itcast.day10.demo02; public abstract class MyInterfaceAbstract implements MyInterfaceA, MyInterfaceB { @Override public void methodA() { } // 沒有寫methodB那么實現(xiàn)類是抽象類 @Override public void methodAbs() { } @Override public void methodDefault() { } }
抽象方法methodB沒有重寫覆蓋,那么實現(xiàn)類成為了抽象類。
5. 如果實現(xiàn)類鎖實現(xiàn)的多個接口當(dāng)中,存在重復(fù)的默認(rèn)方法,那么實現(xiàn)類一定要對沖突的默認(rèn)方法進(jìn)行覆蓋重寫(A,B兩個接口中都寫了默認(rèn)方法,沖突了)。見3.中實現(xiàn)類中覆蓋重寫了A,B中的兩個默認(rèn)方法
6. 一個類如果直接父類當(dāng)中的方法,和接口當(dāng)中的默認(rèn)方法產(chǎn)生了沖突,優(yōu)先用父類當(dāng)中的方法。
Fu類
package cn.itcast.day10.demo02; public class Fu { public void method() { System.out.println("父類方法"); } }
MyInterface接口
package cn.itcast.day10.demo02; public interface MyInterface { public default void method() { System.out.println("接口的默認(rèn)方法"); } }
直接父類當(dāng)中的方法,和接口當(dāng)中的默認(rèn)方法產(chǎn)生了沖突。
Zi子類
package cn.itcast.day10.demo02; public class Zi extends Fu implements MyInterface { }
調(diào)用method方法,看哪個優(yōu)先
package cn.itcast.day10.demo02; public class Demo01Interface { public static void main(String[] args) { Zi zi = new Zi(); zi.method(); } }
調(diào)用子類對象的method方法,發(fā)現(xiàn)使用的是父類中的而不是接口中的方法,父類的優(yōu)先級比接口優(yōu)先級更高。
運行結(jié)果:
父類方法
Process finished with exit code 0
*/
補(bǔ)充知識:java從對象開始(類,父類與繼承,抽象,接口)
1、對象(類class)
在程序設(shè)計時,我們往往會接觸到各種形形色色的現(xiàn)實已存在的對象,這些對象都是需要我們在程序中實例化出來進(jìn)行業(yè)務(wù)操作的。不過從數(shù)量和復(fù)雜上講可以說比我們現(xiàn)實中接觸的事物是有過之而無不及的。
2、父類與繼承
當(dāng)對象類型繁雜數(shù)量繁多時我們就會像生物學(xué)上對各種生物進(jìn)行分門別類,對我們收集到的對象以屬性或者功能又或者其他標(biāo)準(zhǔn)進(jìn)行分類目。而這些我們最終分出來的各種類目往往在程序中被定義為父類,它是對我們收集到的對象中某些具有相同屬性或者功能又或者其他相似特征的對象集合的總稱。好似一個包含各種文件的文件夾,它本身在程序中并無任何業(yè)務(wù)操作的意義。
不過注意的是在不同情形不同問題域下,由于分類標(biāo)準(zhǔn)不同,父類也會成為某個父類的子類,所以會形成一種樹狀關(guān)系結(jié)構(gòu),父類在關(guān)系結(jié)構(gòu)中與其他對象類并無差別。
分類完成后,現(xiàn)在我們就可以以父類為標(biāo)準(zhǔn)來操作一類對象了。但這時我們對分類好的對象進(jìn)行實例化會發(fā)現(xiàn)那些相同的屬性功能或者其他相似特征都需要在其對象中重復(fù)編寫,像這種程度的分類并不是我們想要的。
于是,我們又給父類賦予新的功能,它不再是單純的對對象進(jìn)行分類了。我們提取出相同的屬性和功能特征放在父類中,讓我們需要操作的對象僅僅關(guān)注自己特有的屬性和功能特征,其余的屬性和功能特征都可通過繼承父類來擁有。這樣我們就解決了相同屬性功能重復(fù)編寫的問題,并且還能對共有屬性功能進(jìn)行規(guī)范化操作。
3、抽象類
因為父類并無任何業(yè)務(wù)操作意義,我們就對各種父類進(jìn)行管理為它們添加abstract關(guān)鍵詞,讓它們無法實例化,這樣就避免了實例化對象是不正確的或者某些人分不清具體要操作哪些對象而實例化父類的問題。因為這些父類無法實例化,所以我們把它們稱為——抽象類。通過這樣的設(shè)定我們就會在程序中以抽象類為節(jié)點形成各種層級關(guān)系。
于是我們樹狀關(guān)系機(jī)構(gòu)又變成了具有清晰層級關(guān)系的樹狀關(guān)系結(jié)構(gòu)。
4、小結(jié)
父類的提出是進(jìn)行歸類操作,那么繼承則是去重和規(guī)范化的操作,而抽象在此基礎(chǔ)上又進(jìn)行了關(guān)系的分層級和類對象實例化操作的規(guī)范。
5、接口
前面說我們對每個對象根據(jù)某種特征進(jìn)行分類了,但有時我們會因為某些特有目的標(biāo)準(zhǔn)不一樣,有時以屬性分類有時以功能分類,但有些對象可能擁有相同屬性不擁有相同功能,有些對象擁有相同功能不擁有相同屬性。這時我們就會把這些在父類中沒有的屬性或者功能但其他對象又有相識功能或?qū)傩詥为毘槿〕鰜碜鳛榻涌趤頌檫@些對象服務(wù)。
從抽取相同屬性或者功能這點來看,接口實則是對我們已分類好具有清晰層級的樹狀關(guān)系結(jié)構(gòu)再次進(jìn)行一次去重復(fù)操作,從而我們的對象從具有清晰層級的樹狀關(guān)系結(jié)構(gòu)變成了更加靈活的網(wǎng)狀形結(jié)構(gòu)。
但是在提取父類分類時我們一般會以相同屬性來進(jìn)行分類,那么那些不同的功能會單獨提取到接口中,接口和抽象類相似的是都不會進(jìn)行具體方法功能的實現(xiàn),只是將相同的功能申明好進(jìn)行規(guī)范化操作。具體實現(xiàn)會具體到對象再進(jìn)行實現(xiàn)。
對象進(jìn)行去重再提取后那些因為在不同父類中具有相同功能的對象又以另外一種標(biāo)準(zhǔn)分類到某種接口中了。比如某某對象的某某功能和某某對象的某某功能都是來至于某某接口的。從而我們對對象進(jìn)行操作又多了一種標(biāo)準(zhǔn),可以通過判斷是否具有某種功能進(jìn)行篩選對象進(jìn)其操作。
6、總結(jié)
從功能點上看接口與(抽象和父類和繼承)的提出都是對我們程序中的對象進(jìn)行歸類操作,去除那些重復(fù)的代碼。并且在接口和抽象類中都是可以對某些屬性和方法功能進(jìn)行規(guī)范化約束,從而我們在對對象進(jìn)行業(yè)務(wù)操作中就更加便捷清晰。對象與對象的關(guān)系更加明朗。
以上這篇Java接口操作(繼承父類并實現(xiàn)多個接口)就是小編分享給大家的全部內(nèi)容了,希望能給大家一個參考,也希望大家多多支持腳本之家。
相關(guān)文章
微服務(wù)Spring?Cloud?Alibaba?的介紹及主要功能詳解
Spring?Cloud?是一個通用的微服務(wù)框架,適合于多種環(huán)境下的開發(fā),而?Spring?Cloud?Alibaba?則是為阿里巴巴技術(shù)棧量身定制的解決方案,本文給大家介紹Spring?Cloud?Alibaba?的介紹及主要功能,感興趣的朋友跟隨小編一起看看吧2024-08-08SpringBoot應(yīng)用整合ELK實現(xiàn)日志收集的示例代碼
這篇文章主要介紹了SpringBoot應(yīng)用整合ELK實現(xiàn)日志收集的示例代碼,文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧2020-09-09Java的web開發(fā)中SSH框架的協(xié)作處理應(yīng)用筆記
這篇文章主要介紹了Java的web開發(fā)中SSH框架的協(xié)作處理應(yīng)用筆記,SSH是指Struts和Spring以及Hibernate的框架搭配,需要的朋友可以參考下2015-12-12shrio中hashedCredentialsMatcher密碼匹配示例詳解
shrio是一個輕量級權(quán)限管理框架,密碼的匹配由框架內(nèi)部完成。密碼是否匹配由接口CredentialsMatcher定義實現(xiàn)類完成,CredentialsMatcher實現(xiàn)類有SimpleCredentialsMatcher和HashedCredentialsMatcher兩個2021-10-10