Java 面向對象之繼承篇詳解原理與特點
一、前言
前面我也們講述瞭相關封裝的,現在我們先認識的繼承的概念和使用。
二、繼承
什麼是繼承呢?
繼承在顯示生活中也不少見,比如繼承財產之類的,在我們java學習中也有類似的使用,
繼承者稱作子類也叫派生類,被繼承者稱作父類、基類或超類,objec類是所有類的父類
(後期介紹)
繼承的好處與弊端
好處:就是提高瞭代碼的維護性(多個代碼需要修改,隻需要修該一處即可)。
提高瞭代碼的復用性(多個相同的成員可以方法到同一個類中)
弊端:繼承的缺點就是使代碼之間的耦合度高,修改父類子類也會跟著變化
繼承的使用場景?
兩個有從屬關系的,比如貓和動物,學生和人等。
繼承的關鍵詞是extends。
繼承的格式:
public class 子類名 extends 父類名{}
舉例:
public class Cat extends Animal{}//貓繼承動物類
繼承的特點:
子類可以擁有父類的非私有方法和成員變量,也可以重寫父類的非私有(private修飾的)方法。所有子類的方法都默認訪問父類的無參構造
重寫的概念:
重寫是子類重述父類中的非私有方法,重寫的一般特點是方法名相同,格式相同,返回類型相同、方法體不同
如:
fu類中:
public class fu{ public void play(){ System.out.println("fu喜歡打羽毛球"); } }
zi類中:
public class zi extends fu{ public void play(){//對父類的方法重寫 System.out.println("zi喜歡打籃球"); } }
還可以這麼寫,訪問權限需要zi類大於等於fu類
fu類中修飾是默認:
public class fu{ void eat(){ System.out.println("fu中eat方法"); } }
zi類中:
public class Zi extends Fu { @Override//檢測方法重寫的正確性 public void eat() { System.out.println("zi中的eat方法"); } }
zi類中重寫:
public class Zi extends Fu { // @Override寫不寫不會影響,這個隻是起到輔助作用 void eat() { System.out.println("zi中的eat方法"); } }
zi還可以:
public class Zi extends Fu { @Override protected void eat() { System.out.println("zi中的eat方法"); } }
修飾訪問關系:public>protected>默認(不寫)>private
當父類的權限修飾符是默認(也就是不寫修飾符),子類重寫的修飾方法可以是默認和
默認之前的以此類推。註:當父類的權限修飾符是private時,那子類可不是private
之前的。當父類被private修飾時,子類不能重寫此類方法。
super關鍵字
當子類中的成員變量和父類中成員變量同名時,我們想使用父類中的成員變量時,
或者我們重寫瞭父類中方法時,我們還想調用父類中的方法時。此時我們就要使用super
關鍵字來調用父類中的成員。
super和this的比較
super和this的使用原理差不多,this是解決瞭局部變量和成員變量同名時,局部變量對
成員的覆蓋super是解決子類對父類的覆蓋。
當局部變量,成員變量,父類中的變量同名時,訪問的是局部變量。可以用this和super改變。
public class fu{ public int age=40; public fu(){}//無參構造 public fu(int age){//帶參構造 this.age=age;} public void eat(){ System.out.println("fu中eat方法"); } } public class Zi extends Fu { public int age=18; public Zi(){} public Zi(int age){ this.age=age;} public void eat() { super.eat(); System.out.println("zi中的eat方法"); } public void show(){ int age=1; System.out.println(age);//1局部變量的值 System.out.println(this.age);//18子類成員中的值 System.out.println(super.age);//40父類中的值 } public class Demo{ public static void main(String[] args){ zi z=new zi(); z.eat(); z.show(); } }
下篇我們繼續!!
到此這篇關於Java 面向對象之繼承篇詳解原理與特點的文章就介紹到這瞭,更多相關Java 繼承內容請搜索WalkonNet以前的文章或繼續瀏覽下面的相關文章希望大傢以後多多支持WalkonNet!