本文目錄一覽:
JAVA中接口具體該怎麼使用
首先是申明一個接口,關鍵字:interface,語法:
public
interface
MyInterface
{
….
}
在主體內部可以定義一些常量和接口的申明!例如:
public
interface
MyInterface
{
public
static
final
int
price=14;
public
void
dis(int
param);
}
需要注意一點:接口中申明的所有方法必須是public或者是默認類型!
而且只要申明,不要去實現它!
如果要使用這個接口,那就要寫一個類去實現它,關鍵字:implements
public
class
MyInterfaceDemo
implements
MyInterface{
…….
}
注意:要去實現一個接口的時候,必須去實現接口中定義的所有方法,除非你的類申明為abstract(是一個抽象類)!
java 接口怎麼用?應該怎麼實現?
java語言不支持一個類有多個直接的父類(多繼承),但可以實現(implements)多個接口,間接的實現了多繼承
用法public class test implements 接口名稱
當類實現了某個Java接口時,它必須實現接口中的所有抽象方法,否則這個類必須聲明為抽象的
比較抽象類與接口
1, 抽象類與接口都位於繼承樹的上層
相同點
1, 代表系統的抽象層,當一個系統使用一顆繼承樹上的類時,應該盡量把引用變量聲明為繼承樹的上層抽象類型,這樣可以提高兩個系統之間的送耦合
2, 都不能被實例化
3, 都包含抽象方法,這些抽象方法用於描述系統能提供哪些服務,但不提供具體的實現
不同點:
1, 在抽象類中可以為部分方法提供默認的實現,從而避免在子類中重複實現它們,這是抽象類的優勢,但這一優勢限制了多繼承,而接口中只能包含抽象方法.由於在抽象類中允許加入具體方法,因此擴展抽象類的功能,即向抽象類中添加具體方法,不會對它的子類造成影響,而對於接口,一旦接口被公布,就必須非常穩定,因為隨意在接口中添加抽象方法,會影響到所有的實現類,這些實現類要麼實現新增的抽象方法,要麼聲明為抽象類
2, 一個類只能繼承一個直接的父類,這個父類可能是抽象類,但一個類可以實現多個接口,這是接口的優勢,但這一優勢是以不允許為任何方法提供實現作為代價的三, 為什麼Java語言不允許多重繼承呢?當子類覆蓋父類的實例方法或隱藏父類的成員變量及靜態方法時,Java虛擬機採用不同的綁定規則,假如還允許一個類有多個直接的父類,那麼會使綁定規則更加複雜,
因此,為了簡化系統結構設計和動態綁定機制,Java語言禁止多重繼承.而接口中只有抽象方法,沒有實例變量和靜態方法,只有接口的實現類才會實現接口的抽象方法(接口中的抽象方法是通過類來實現的),因此,一個類即使有多個接口,也不會增加Java虛擬機進行動態綁定的複雜度.因為Java虛擬機永遠不會把方法與接口綁定,而只會把方法與它的實現類綁定.四, 使用接口和抽象類的總體原則:
1, 用接口作為系統與外界交互的窗口站在外界使用者(另一個系統)的角度,接口向使用者承諾系統能提供哪些服務,站在系統本身的角度,接口制定系統必須實現哪些服務,接口是系統中最高層次的抽象類型.通過接口交互可以提高兩個系統之間的送耦合系統A通過系統B進行交互,是指系統A訪問系統B時,把引用變量聲明為系統B中的接口類型,該引用變量引用系統B中接口的實現類的實例。
public interface B
{
}
public class C implements B
{
}
public class A
{
}
B a = new C();
2, Java接口本身必須非常穩定,Java接口一旦制定,就不允許隨遇更加,否則對外面使用者及系統本身造成影響
3, 用抽象類來定製系統中的擴展點
抽象類來完成部分實現,還要一些功能通過它的子類來實現
java 接口到底怎麼用 ?到底應該怎麼實現?
接口是很重要的面向對象方式,繼承接口的類不用全部實現定義的接口,可以這麼說,我定義了好多接口,某個類可以這麼實現這個接口,到另一個類你又想那麼實現接口,都是可以的。
或者定義完接口不想管他都可以,雖然很冗餘。接口不多了不影響操作。
比如:
定義了一個線性表接口。
public interface Ilist {
public void clear();
public boolean isEmpty();
public int length();
}
我想具體實現的話就建立以下實現類:
import dao.Ilist;
public class SqList implements Ilist {
private Object[] listElem;// 線性表存儲空間
private int curLen;// 線性表的當前長度
// 順序表的構造函數,構造一個存儲空間容量為maxSize的線性表
public SqList(int maxSize) {
curLen = 0;
listElem = new Object[maxSize];
}
public void clear() {
curLen = 0;
}
public boolean isEmpty() {
return curLen == 0;// curLen==0時為true,!=0時為false;
}
public int length() {
return curLen;
}
原創文章,作者:小藍,如若轉載,請註明出處:https://www.506064.com/zh-hant/n/183489.html