接口與抽象類
定義
抽象類為它衍生出去的所有類,都創(chuàng)建了通用的接口,它能為不同的子類型做出不同的表示。
包含了抽象方法的類就是抽象類,一個(gè)類如果有一個(gè)或多個(gè)抽象方法,就必須是抽象類。
抽象類同樣也可以不包含抽象方法,如果想讓一個(gè)類不創(chuàng)建實(shí)例,可以定義為抽象類。
接口
使用接口,可以上溯類型至多個(gè)基礎(chǔ)類,可以防止一個(gè)類創(chuàng)建這個(gè)類的對(duì)象
接口和抽象類的選用
如果知道要定義成基礎(chǔ)類,第一選擇就是定義成接口,只有在必須使用方法定義或者成員變量的時(shí)候,在應(yīng)該考慮抽象類。
接口支持多重繼承
多態(tài)
“對(duì)于面向?qū)ο蟮某绦蛟O(shè)計(jì)語言,多型性是第三種最基本的特征(前兩種是數(shù)據(jù)抽象和繼承)?!?/p>
上溯造型
上溯造型就是,在有繼承關(guān)系的兩個(gè)類中,在要求使用子類引用的地方,使用父類的引用。
大家已知道可將一個(gè)對(duì)象作為它自己的類型使用,或者作為它的基礎(chǔ)類型的一個(gè)對(duì)象使用。取得一個(gè)對(duì)象句柄,并將其作為基礎(chǔ)類型句柄使用的行為就叫作“上溯造型” —— 因?yàn)槔^承樹的畫法是基礎(chǔ)類位于最上方。
后期綁定
java中所有的方法綁定都是采用后期綁定技術(shù)(也叫動(dòng)態(tài)綁定,運(yùn)行期綁定)
它意味著綁定在運(yùn)行期間進(jìn)行,以對(duì)象的類型為基礎(chǔ)。
public class Shape {
public void draw() {}
public void size() {}
}
public class Circle extends Shape{
@Override
public void draw() {
System.out.println("Circle draw()");
}
@Override
public void size() {}
public static void main(String[] args) {
Shape shape = new Circle();
//此時(shí)調(diào)用的是Circle.draw();因?yàn)楹笃诮壎夹g(shù)已經(jīng)介入(多形性)。
shape.draw();
}
}
final修飾的方法
final修飾的方法無法被覆蓋,但是更重要的一點(diǎn)它可關(guān)閉動(dòng)態(tài)綁定,這樣編譯器可為final方法調(diào)用生成效率更高的代碼。
運(yùn)算符
于前遞增和前遞減(如++A 或--A),會(huì)先執(zhí)行運(yùn)算,再生成值。而對(duì)于后遞增和后遞減(如A++或 A--),會(huì)先生成值,再執(zhí)行運(yùn)算。下面是一個(gè)例子:
public class AutoInc {
public static void main(String[] args) {
int i = 1;
prt("i : " + i);
prt("++i : " + ++i); // Pre-increment
prt("i++ : " + i++); // Post-increment
prt("i : " + i);
prt("--i : " + --i); // Pre-decrement
prt("i-- : " + i--); // Post-decrement
prt("i : " + i);
}
static void prt(String s) {
System.out.println(s);
}
}
該程序的輸出如下:
i : 1
++i : 2
i++ : 2
i : 3
--i : 2
i-- : 2
== 和 equals()的區(qū)別
如果是兩個(gè)對(duì)象使用==來比較的話,默認(rèn)比較的是引用的地址值是否一樣,而equals()比較的是兩個(gè)對(duì)象具體的值是否相等。但是有個(gè)例外情況,如果是自己創(chuàng)建的對(duì)象,并且這個(gè)對(duì)象沒有復(fù)寫equals()這個(gè)方法的話,默認(rèn)比較 的是引用的地址值,就和==一樣了。
break 和 continue
break用于強(qiáng)制退出循環(huán),不執(zhí)行剩余的語句
continue結(jié)束當(dāng)前循環(huán),不執(zhí)行后面的語句,直接繼續(xù)循環(huán)