Java基礎(chǔ)第五篇 實(shí)施接口
在上一篇文章封裝與接口中,private關(guān)鍵字封裝了對(duì)象的內(nèi)部成員。經(jīng)過(guò)封裝,產(chǎn)品隱藏了內(nèi)部細(xì)節(jié),只提供給用戶接口(interface)。
接口是非常有用的概念,可以輔助我們的抽象思考。在現(xiàn)實(shí)生活中,當(dāng)我們想起某個(gè)用具的時(shí)候,往往想到的是該用具的功能性接口。比如杯子,我們想到加水和喝水的可能性,高于想到杯子的材質(zhì)和價(jià)格。也就是說(shuō),一定程度上,用具的接口等同于用具本身。內(nèi)部細(xì)節(jié)則在思考過(guò)程中被摒棄。

在public和private的封裝機(jī)制,我們實(shí)際上同時(shí)定義了類和接口,類和接口混合在一起。Java還提供了interface這一語(yǔ)法。這一語(yǔ)法將接口從類的具體定義中剝離出來(lái),構(gòu)成一個(gè)獨(dú)立的主體。
1、interface
以杯子為例,定義一個(gè)杯子的接口:
interface Cup {
void addWater(int w);
void drinkWater(int w);
}
Cup這個(gè)interface中定義了兩個(gè)方法的原型(stereotype): addWater()和drinkWater()。一個(gè)方法的原型規(guī)定了方法名,參數(shù)列表和返回類型。原型可以告訴外部如何使用這些方法。
在interface中,我們應(yīng)注意:
- 不需要定義方法的主體
- 不需要說(shuō)明方法的可見(jiàn)性
特別注意第二點(diǎn),interface中的方法默認(rèn)為public。正如我們?cè)诜庋b與接口中講到的,一個(gè)類的public方法構(gòu)成了接口。所以,所有出現(xiàn)在interface中的方法都默認(rèn)為public。
我們可以在一個(gè)類的定義中實(shí)施接口,比如下面的MusicCup (可以播放音樂(lè)的杯子):
class MusicCup implements Cup
{
public void addWater(int w)
{
this.water = this.water + w;
}
public void drinkWater(int w)
{
this.water = this.water - w;
}
private int water = 0;
}
我們用implements關(guān)鍵字來(lái)實(shí)施interface。一旦在類中實(shí)施了某個(gè)interface,必須在該類中定義interface的所有方法(addWater()和drinkWater())。類中的方法需要與interface中的方法原型相符。否則,Java將報(bào)錯(cuò)。
在類中可以定義interface沒(méi)有提及的其他public方法。也就是說(shuō),interface規(guī)定一個(gè)必須要實(shí)施的最小接口。比如下面的waterContent()方法就沒(méi)有在Cup接口中規(guī)定原型:
class MusicCup implements Cup
{
public void addWater(int w)
{
this.water = this.water + w;
}
public void drinkWater(int w)
{
this.water = this.water - w;
}
public int waterContent()
{
return this.water;
}
private int water = 0;
}
2、分離接口的意義
我們使用了interface,但這個(gè)interface并沒(méi)有減少我們定義類時(shí)的工作量。我們依然要像之前一樣,具體的編寫類。我們甚至于要更加小心,不能違反了interface的規(guī)定。既然如此,我們?yōu)槭裁匆褂胕nterface呢?
事實(shí)上,interface就像是行業(yè)標(biāo)準(zhǔn)。一個(gè)工廠(類)可以采納行業(yè)標(biāo)準(zhǔn) (implement interface),也可以不采納行業(yè)標(biāo)準(zhǔn)。但是,一個(gè)采納了行業(yè)標(biāo)準(zhǔn)的產(chǎn)品將有下面的好處:
- 更高質(zhì)量: 沒(méi)有加水功能的杯子不符合標(biāo)準(zhǔn)。
- 更容易推廣: 正如電腦上的USB接口一樣,下游產(chǎn)品可以更容易銜接。
如果我們已經(jīng)有一個(gè)Java程序,用于處理符合Cup接口的對(duì)象,比如領(lǐng)小朋友喝水。那么,只要我們確定,我們給小朋友的杯子(對(duì)象)實(shí)施了Cup接口,就可以確保小朋友可以執(zhí)行喝水這個(gè)動(dòng)作了。至于這個(gè)杯子(對(duì)象)是如何具體定義喝水這個(gè)動(dòng)作的,我們就可以留給相應(yīng)的類自行決定 (比如用吸管喝水,或者開(kāi)一個(gè)小口喝水)。
在計(jì)算機(jī)科學(xué)中,接口是很重要的概念。比如任何提供UNIX接口的操作系統(tǒng)都可以稱作UNIX系統(tǒng)。Linux,Mac OS,Solaris都是UNIX系統(tǒng),它們提供相似的接口。但是,各個(gè)系統(tǒng)的具體實(shí)施(源代碼)互不相同。Linux是開(kāi)源的,你可以查看它的每一行代碼,但你還是不知道如何去編寫一個(gè)Solaris系統(tǒng)。
相同的UNIX接口:

3、實(shí)施多個(gè)接口
一個(gè)類可以實(shí)施不止一個(gè)的interface。比如我們有下面一個(gè)interface:
interface MusicPlayer {
void play();
}
我們?cè)賮?lái)考慮MusicCup類。MusicCup可以看做播放器和杯子的混合體。

所以MusicCup應(yīng)該具備兩套接口,即同時(shí)實(shí)施MusicPlayer接口和Cup接口:
class MusicCup implements MusicPlayer, Cup
{
public void addWater(int w)
{
this.water = this.water + w;
}
public void drinkWater(int w)
{
this.water = this.water - w;
}
public void play()
{
System.out.println("la...la...la");
}
private int water = 0;
}
最后,可以嘗試將本文中的interface和類定義放在同一個(gè)文件中,并編寫Test類,運(yùn)行一下。
4、總結(jié)
interface, method stereotype, public
implements interface
implements interface1, interface2
到此這篇關(guān)于Java基礎(chǔ)第五篇 實(shí)施接口的文章就介紹到這了,更多相關(guān)Java實(shí)施接口內(nèi)容請(qǐng)搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
相關(guān)文章
Struts中使用validate()輸入校驗(yàn)方法詳解
這篇文章主要介紹了Struts中使用validate()輸入校驗(yàn)方法,本文介紹的非常詳細(xì),具有參考借鑒價(jià)值,感興趣的朋友一起看看吧2016-09-09
Spring MVC文件上傳大小和類型限制以及超大文件上傳bug問(wèn)題
這篇文章主要介紹了Spring MVC文件上傳大小和類型限制以及超大文件上傳bug問(wèn)題,非常具有實(shí)用價(jià)值,需要的朋友可以參考下2017-10-10
解決常見(jiàn)的Eclipse SVN插件報(bào)錯(cuò)方法詳解
本篇文章是對(duì)常見(jiàn)的Eclipse SVN插件報(bào)錯(cuò)方法進(jìn)行了詳細(xì)的分析介紹,需要的朋友參考下2013-05-05
Spring lazy-init 懶加載的原理小結(jié)
lazy-init 是一個(gè)非常重要的屬性,可以優(yōu)化應(yīng)用的啟動(dòng)時(shí)間,尤其是在處理大量bean或者復(fù)雜依賴關(guān)系時(shí),可以顯著提高應(yīng)用的響應(yīng)速度,本文主要介紹了Spring lazy-init 懶加載的原理小結(jié),感興趣的可以了解一下2025-04-04
Java幸運(yùn)28系統(tǒng)搭建數(shù)組的使用實(shí)例詳解
在本篇文章里小編給大家整理了關(guān)于Java幸運(yùn)28系統(tǒng)搭建數(shù)組的使用實(shí)例內(nèi)容,有需要的朋友們可以參考學(xué)習(xí)下。2019-09-09

