08.01_面向?qū)ο?代碼塊的概述和分類)(了解)(面試的時候會問,開發(fā)不用或者很少用)
- A:代碼塊概述
- 在Java中赠橙,使用{}括起來的代碼被稱為代碼塊呆细。
- B:代碼塊分類
- 根據(jù)其位置和聲明的不同,可以分為局部代碼塊,構(gòu)造代碼塊,靜態(tài)代碼塊,同步代碼塊(多線程講解)啥辨。
- C:常見代碼塊的應(yīng)用
- a:局部代碼塊
- 在方法中出現(xiàn);限定變量生命周期盯腌,及早釋放溉知,提高內(nèi)存利用率
- b:構(gòu)造代碼塊 (初始化塊)
- 在類中方法外出現(xiàn);多個構(gòu)造方法方法中相同的代碼存放到一起,每次調(diào)用構(gòu)造都執(zhí)行着倾,并且在構(gòu)造方法前執(zhí)行
- c:靜態(tài)代碼塊
- 在類中方法外出現(xiàn)拾酝,并加上static修飾;用于給類進行初始化卡者,在加載的時候就執(zhí)行蒿囤,并且只執(zhí)行一次。
- 一般用于加載驅(qū)動
- a:局部代碼塊
08.02_面向?qū)ο?代碼塊的面試題)(掌握)
- A:看程序?qū)懡Y(jié)果
class Student { static { System.out.println("Student 靜態(tài)代碼塊"); } { System.out.println("Student 構(gòu)造代碼塊"); } public Student() { System.out.println("Student 構(gòu)造方法"); } } class Demo2_Student { static { System.out.println("Demo2_Student靜態(tài)代碼塊"); } public static void main(String[] args) { System.out.println("我是main方法"); Student s1 = new Student(); Student s2 = new Student(); } }
08.03_面向?qū)ο?繼承案例演示)(掌握)
- A:繼承(extends)
- 讓類與類之間產(chǎn)生關(guān)系,子父類關(guān)系
- B:繼承案例演示:
- 動物類,貓類,狗類
- 定義兩個屬性(顏色,腿的個數(shù))兩個功能(吃飯崇决,睡覺)
class ThisClass extends SuperClass //extends繼承
{
}
08.04_面向?qū)ο?繼承的好處和弊端)(掌握)
- A:繼承的好處
- a:提高了代碼的復(fù)用性
- b:提高了代碼的維護性
- c:讓類與類之間產(chǎn)生了關(guān)系材诽,是多態(tài)的前提
- B:繼承的弊端
- 類的耦合性增強了。
- 開發(fā)的原則:高內(nèi)聚恒傻,低耦合脸侥。
- 耦合:類與類的關(guān)系
- 內(nèi)聚:就是自己完成某件事情的能力
08.05_面向?qū)ο?Java中類的繼承特點)(掌握)
- A:Java中類的繼承特點
- a:Java只支持單繼承,不支持多繼承盈厘。(一個兒子只能有一個爹)
- 有些語言是支持多繼承睁枕,格式:extends 類1,類2,...
- b:Java支持多層繼承(繼承體系)
- Java中類的繼承特點
- 如果想用這個體系的所有功能用最底層的類創(chuàng)建對象
- 如果想看這個體系的共性功能,看最頂層的類
- a:Java只支持單繼承,不支持多繼承盈厘。(一個兒子只能有一個爹)
08.06_面向?qū)ο?繼承的注意事項和什么時候使用繼承)(掌握)
-
A:繼承的注意事項
- a:子類只能繼承父類所有非私有的成員(成員方法和成員變量)(反射這種情況另講)
- b:子類不能繼承父類的構(gòu)造方法,但是可以通過super(馬上講)關(guān)鍵字去訪問父類構(gòu)造方法沸手。
- c:不要為了部分功能而去繼承
-
B:什么時候使用繼承
- 繼承其實體現(xiàn)的是一種關(guān)系:"is a"外遇。
Person --> (Student / Teacher)
水果 --> (蘋果 / 香蕉 / 橘子)
采用假設(shè)法。
如果有兩個類A,B契吉。只有他們符合A是B的一種跳仿,或者B是A的一種,就可以考慮使用繼承捐晶。 - 繼承其實體現(xiàn)的是一種關(guān)系:"is a"外遇。
08.08_面向?qū)ο?this和super的區(qū)別和應(yīng)用)(掌握)
- A:this和super都代表什么
- this:代表當前對象的引用,誰來調(diào)用我,我就代表誰
- super:代表當前對象父類的引用
- B:this和super的使用區(qū)別
- a:調(diào)用成員變量
- this.成員變量 調(diào)用本類的成員變量,也可以調(diào)用父類的成員變量
- super.成員變量 調(diào)用父類的成員變量
- b:調(diào)用構(gòu)造方法
- this(...) 調(diào)用本類的構(gòu)造方法
- super(...) 調(diào)用父類的構(gòu)造方法
- c:調(diào)用成員方法
- this.成員方法 調(diào)用本類的成員方法,也可以調(diào)用父類的方法
- super.成員方法 調(diào)用父類的成員方法
- a:調(diào)用成員變量
08.09_面向?qū)ο?繼承中構(gòu)造方法的關(guān)系)(掌握)
- A:案例演示
- 子類中所有的構(gòu)造方法默認都會訪問父類中空參數(shù)的構(gòu)造方法
- B:為什么呢?
因為子類會繼承父類中的數(shù)據(jù)菲语,可能還會使用父類的數(shù)據(jù)。
所以惑灵,子類初始化之前山上,一定要先完成父類數(shù)據(jù)的初始化。
其實:
*** 每一個構(gòu)造方法的第一條語句默認都是:super() Object類最頂層的父類泣棋,寫不寫胶哲,都會有的畔塔。**
08.10_面向?qū)ο?繼承中構(gòu)造方法的注意事項)(掌握)
- A:案例演示
- 父類沒有無參構(gòu)造方法,子類怎么辦?
- super解決
- this解決
- B:注意事項
- super(…)或者this(….)必須出現(xiàn)在構(gòu)造方法的第一條語句上潭辈,不能同時出現(xiàn)super和this。
08.11_面向?qū)ο?繼承中的面試題)(掌握)
- 看程序?qū)懡Y(jié)果一
class Fu {
public int num;
public Fu(){
System.out.println("fu");
}
}
class Zi extends Fu {
public int num = 20;
public Zi() {
System.out.println("zi");
}
public void show(){
int num = 30;
System.out.println(num);
System.out.println(this.num); //輸出20
System.out.println(super.num); //輸出10 好好理解為什么二者不為啥不一樣
}
}
// 運行語句
Zi zz = new Zi();
zz.show();
// 分析
// java中繼承關(guān)系的父子類澈吨,相同的方法會被重寫
// 屬性沒有重寫之說把敢,如果子類聲明了跟父類一樣的屬性,那意謂著子類中將有兩個相同名稱的屬性
// 例子中谅辣,F(xiàn)u和Zi類都有一個屬性 num
// 但是在子類中修赞,this.num 和 super.num 卻是輸出不同的值,證明了此點。
- 看程序?qū)懡Y(jié)果二
class Fu {
static {
System.out.println("靜態(tài)代碼塊Fu");
}
{
System.out.println("構(gòu)造代碼塊Fu");
}
public Fu() {
System.out.println("構(gòu)造方法Fu");
}
}
class Zi extends Fu {
static {
System.out.println("靜態(tài)代碼塊Zi");
}
{
System.out.println("構(gòu)造代碼塊Zi");
}
public Zi() {
System.out.println("構(gòu)造方法Zi");
}
}
// 運行語句
Zi s2 = new Zi();
// 輸出結(jié)果是
靜態(tài)代碼塊Fu
靜態(tài)代碼塊Zi
構(gòu)造代碼塊Fu
構(gòu)造方法Fu
構(gòu)造代碼塊Zi
構(gòu)造方法Zi
// 分析
// 1.JVM調(diào)用main方法柏副,main方法進棧
// 2.遇到Zi s2 = new Zi();會將Fu.class和Zi.class分別加載到方法區(qū)內(nèi)存
// 當Fu.class加載到內(nèi)存勾邦,父類的靜態(tài)代碼塊會隨著Fu.class一起加載
// 當Zi.class加載到內(nèi)存,子類的靜態(tài)代碼塊會隨著Zi.class一起加載
// 3.走子類構(gòu)造方法割择,構(gòu)造方法的分層初始化:先初始化父類眷篇,再初始化子類,但是
// 在實行父類構(gòu)造方法時荔泳,發(fā)現(xiàn)父類有構(gòu)造代碼塊蕉饼,構(gòu)造代碼塊是優(yōu)先于構(gòu)造方法執(zhí)行的。
// 4.所以先輸出父類的構(gòu)造代碼塊-->構(gòu)造方法玛歌,其次是子類的構(gòu)造代碼塊-->構(gòu)造方法
08.12_面向?qū)ο?繼承中成員方法關(guān)系)(掌握)
- a:不同名的方法 --> 沒有關(guān)系昧港,子類都會有方法
- b:同名的方法 --> 重寫 ( 覆蓋)
- 這里注意 重寫 和 重載 。重載是指的方法名相同支子,參數(shù)列表不一樣
08.13_面向?qū)ο?方法重寫概述及其應(yīng)用)(掌握)
- A:什么是方法重寫
- 重寫:子父類出現(xiàn)了一模一樣的方法(注意:返回值類型可以是子父類,這個我們學(xué)完面向?qū)ο笾v)
- B:方法重寫的應(yīng)用:
- 當子類需要父類的功能创肥,而功能主體子類有自己特有內(nèi)容時,可以重寫父類中的方法值朋。這樣瓤的,即沿襲了父類的功能,又定義了子類特有的內(nèi)容吞歼。
08.14_面向?qū)ο?方法重寫的注意事項)(掌握)
- A:方法重寫注意事項
-
a:父類中私有方法不能被重寫
- 因為父類私有方法子類根本就無法繼承
-
b:子類重寫父類方法時圈膏,訪問權(quán)限不能更低
- 最好就一致
-
c:父類靜態(tài)方法,子類也必須通過靜態(tài)方法進行重寫
- 其實這個算不上方法重寫篙骡,但是現(xiàn)象確實如此稽坤,至于為什么算不上方法重寫,多態(tài)中我會講解(靜態(tài)只能覆蓋靜態(tài))
子類重寫父類方法的時候糯俗,最好聲明一模一樣尿褪。
-
08.15_面向?qū)ο?方法重寫的面試題)(掌握)
- A:方法重寫的面試題
Override和Overload的區(qū)別?Overload能改變返回值類型嗎?
overload可以改變返回值類型,只看參數(shù)列表
方法重寫:子類中出現(xiàn)了和父類中方法聲明一模一樣的方法。與返回值類型有關(guān),返回值是一致(或者是子父類)的
方法重載:本類中出現(xiàn)的方法名一樣得湘,參數(shù)列表不同的方法杖玲。與返回值類型無關(guān)。
-
子類對象調(diào)用方法的時候:
- 先找子類本身淘正,再找父類摆马。
08.19_面向?qū)ο?final關(guān)鍵字修飾類,方法以及變量的特點)(掌握)
- A:final概述
- B:final修飾特點
- 修飾類,類不能被繼承
- 修飾變量鸿吆,變量就變成了常量囤采,只能被賦值一次
- 修飾方法,方法不能被重寫
// 修飾變量惩淳,變量就變成了常量蕉毯,只能被賦值一次
// 常量命名一般都是大寫
// final常量,一般會與public和static一起修飾
public static final int NUMBER_XXOO = 100 ;
public final void xxoo(final int a)
{
a++ ; //報錯 final修飾方法參數(shù),參數(shù)值不能被改變
System.out.println("final修飾方法代虾,方法不能被重寫");
}
final class FinalClass //final修飾類进肯,類不能被繼承:不能擁有子類
{
}
08.20_面向?qū)ο?final關(guān)鍵字修飾局部變量)(掌握)
- 方法內(nèi)部或者方法聲明上都演示一下(了解)
- 基本類型,是值不能被改變
- 引用類型棉磨,是地址值不能被改變,對象中的屬性可以改變
final Person p = new Person();
p = new Person(); //報錯坷澡,因為p指向的地址是final,不能再改變
p.name = "XXOO1"; //不會報錯
p.name = "XXOO2";
08.21_面向?qū)ο?final修飾變量的初始化時機)(掌握)
- A:final修飾變量的初始化時機
- 顯示初始化
- 在對象構(gòu)造完畢前即可
END含蓉。
我是小侯爺频敛。
在魔都艱苦奮斗,白天是上班族馅扣,晚上是知識服務(wù)工作者斟赚。
如果讀完覺得有收獲的話,記得關(guān)注和點贊哦差油。
非要打賞的話拗军,我也是不會拒絕的。