第19條 接口只用于定義類型

當(dāng)類實現(xiàn)接口時嗜暴,接口就充當(dāng)可以引用這個類的實例的類型。因此,類實現(xiàn)了接口姨蟋,就表明客戶端對這個類的實例可以實施某些動作。為了任何其他目的而定義的接口是不恰當(dāng)?shù)摹?/p>

? ? ? 有一種接口被稱為常量接口(constant interface),這種接口沒有包含任何方法立帖,它只包含靜態(tài)的final域眼溶,每個域都導(dǎo)出一個常量。下面是一個例子

public interface PhysicalConstants {
? ?static final double AVOGADROS_NUMBER ?= 6.23156412e23; //阿伏伽德羅數(shù)
? ?static final double BOLTZMANN_CONSTANT ?= 1.12588456e-23; //玻爾茲曼常數(shù)
? ?static final double ELECTRON_MASS = 9.10938188e-31; //電子質(zhì)量
}

? ? ? 常量接口模式是對接口的不良使用晓勇。類在內(nèi)部使用某些常量堂飞,純粹是實現(xiàn)細(xì)節(jié),實現(xiàn)常量接口绑咱,會導(dǎo)致把這樣的實現(xiàn)細(xì)節(jié)泄露到該類的導(dǎo)出API中绰筛,因為接口中所有的域及方法都是public的。類實現(xiàn)常量接口描融,代表了一種承諾:如果在將來的發(fā)行版本中铝噩,這個類被修改了,它不再需要使用這些常量了窿克,依然必須實現(xiàn)這個接口骏庸,以確保二進制兼容性。如果非final類實現(xiàn)了常量接口年叮,它的所有子類的命名空間都受到了污染具被。

那既然不適合存在全部都是導(dǎo)出常量的常量接口,那么如果需要導(dǎo)出常量谋右,它們應(yīng)該放在哪里呢硬猫?

1.如果這些常量與某些現(xiàn)有的類或者接口緊密相關(guān),就應(yīng)該把這些常量添加到這個類或者接口中(如Integer和Double)改执,注意啸蜜,這里說添加到接口中并不是指的常量接口。在Java平臺類庫中所有的數(shù)值包裝類都導(dǎo)出MIN_VALUE和MAX_VALUE常量辈挂。如果這些常量最好被看作是枚舉類型成員衬横,那就應(yīng)該用枚舉類型來導(dǎo)出终蒂。

如:int類型的取值范圍是多少?

這就應(yīng)該去查 Integer -- Integer.MAX_VALUE;

public enum PhysicalConstants {
? ? ? ?AVOGADROS_NUMBER(6.23156412e23),BOLTZMANN_CONSTANT(1.12588456e-23),ELECTRON_MASS(9.10938188e-31);
? ? ? ?private final Double constant;
? ? ? ?PhysicalConstants(Double number) {
? ? ? ? ? ? ?thie.constant = number;
? ? ? ?}
? ? ? ?public Double constant() {
? ? ? ? ? ? ?return constant;
? ? ? ?}
}

2.應(yīng)該使用不可實例化的工具類來導(dǎo)出這些常量矮锈。

public class PhysicalConstants {
? ?private PhysicalConstants() {}
? ?public static final double AVOGADROS_NUMBER = 6.23156412e23;
? ?public static final double BOLTZMANN_CONSTANT = 1.12588456e-23;
? ?...
}

工具類通常要求客戶端要用類名來修飾這些常量名。例如PhysicalConstants.AVOGADROS_NUMBER瀑凝。如果大量利用工具類導(dǎo)出的常量,那么可以通過靜態(tài)導(dǎo)入(static import)機制來避免用類名來修飾常量名粤咪。靜態(tài)導(dǎo)入的作用是把PhysicalConstants類中的AVOGADROS_NUMBER 渴杆、BOLTZMANN_CONSTANT 等常量引入到本類中,這會使程序更簡單脉顿,更容易閱讀,只要看到AVOGADROS_NUMBER就知道這是阿伏伽德羅常數(shù)敢辩,不用每次都要把類名寫全了戚长。但是,濫用靜態(tài)導(dǎo)入會使程序更難閱讀柑司,更難維護迫肖。

// Use of static import to avoid qualifying constants ?
import static effectivejava.PhysicalConstants.*; ?
?
public class Test { ?
? ?double atoms(double mols) { ?
? ? ? ?return AVOGADROS_NUMBER?* mols; ?
? ?} ?
? ?... ?
? ?// Many more uses of PhysicalConstants justify static import ?
}

PS:在Java程序中蟆湖,是不允許定義獨立的函數(shù)和常量(準(zhǔn)確的說诬垂,只是被final修飾充蓝、只能賦值一次的變量)的。即使從它們本身的功能來看悠垛,完全不需要依附于什么東西,也要找個類或接口作為掛靠單位才行(在類里可以掛靠各種成員,而接口里則只能掛靠常量)。

? ? ? ?掛靠的方法近迁,是把它們加上static修飾符鉴竭,定義為這個類或接口的靜態(tài)成員瑰步。這方面的典型例子是java.lang.Math類——包含了大量的sin责静、cos這樣的“函數(shù)”和PI、E這樣的“常量”睦焕。

? ? ? ?傳統(tǒng)上藐握,在訪問這些掛靠了的函數(shù)靴拱、變量和常量的時候,需要在前面加上它們掛靠單位的名稱猾普。如果只是偶爾訪問這些東西一下袜炕,這樣的寫法可以工作得很好;但是如果要頻繁訪問這些成員的話初家,這樣的寫法就顯得比較羅嗦了偎窘。

簡而言之,接口應(yīng)該只用來定義類型溜在,它不應(yīng)該被用來導(dǎo)出常量陌知。

最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請聯(lián)系作者
  • 序言:七十年代末,一起剝皮案震驚了整個濱河市掖肋,隨后出現(xiàn)的幾起案子仆葡,更是在濱河造成了極大的恐慌,老刑警劉巖志笼,帶你破解...
    沈念sama閱讀 211,194評論 6 490
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件沿盅,死亡現(xiàn)場離奇詭異,居然都是意外死亡纫溃,警方通過查閱死者的電腦和手機腰涧,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 90,058評論 2 385
  • 文/潘曉璐 我一進店門,熙熙樓的掌柜王于貴愁眉苦臉地迎上來紊浩,“玉大人窖铡,你說我怎么就攤上這事》凰” “怎么了万伤?”我有些...
    開封第一講書人閱讀 156,780評論 0 346
  • 文/不壞的土叔 我叫張陵,是天一觀的道長呜袁。 經(jīng)常有香客問我,道長简珠,這世上最難降的妖魔是什么阶界? 我笑而不...
    開封第一講書人閱讀 56,388評論 1 283
  • 正文 為了忘掉前任,我火速辦了婚禮聋庵,結(jié)果婚禮上膘融,老公的妹妹穿的比我還像新娘。我一直安慰自己祭玉,他們只是感情好氧映,可當(dāng)我...
    茶點故事閱讀 65,430評論 5 384
  • 文/花漫 我一把揭開白布。 她就那樣靜靜地躺著脱货,像睡著了一般岛都。 火紅的嫁衣襯著肌膚如雪律姨。 梳的紋絲不亂的頭發(fā)上,一...
    開封第一講書人閱讀 49,764評論 1 290
  • 那天臼疫,我揣著相機與錄音择份,去河邊找鬼。 笑死烫堤,一個胖子當(dāng)著我的面吹牛荣赶,可吹牛的內(nèi)容都是我干的。 我是一名探鬼主播鸽斟,決...
    沈念sama閱讀 38,907評論 3 406
  • 文/蒼蘭香墨 我猛地睜開眼拔创,長吁一口氣:“原來是場噩夢啊……” “哼!你這毒婦竟也來了富蓄?” 一聲冷哼從身側(cè)響起剩燥,我...
    開封第一講書人閱讀 37,679評論 0 266
  • 序言:老撾萬榮一對情侶失蹤,失蹤者是張志新(化名)和其女友劉穎格粪,沒想到半個月后躏吊,有當(dāng)?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體,經(jīng)...
    沈念sama閱讀 44,122評論 1 303
  • 正文 獨居荒郊野嶺守林人離奇死亡帐萎,尸身上長有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點故事閱讀 36,459評論 2 325
  • 正文 我和宋清朗相戀三年比伏,在試婚紗的時候發(fā)現(xiàn)自己被綠了。 大學(xué)時的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片疆导。...
    茶點故事閱讀 38,605評論 1 340
  • 序言:一個原本活蹦亂跳的男人離奇死亡赁项,死狀恐怖,靈堂內(nèi)的尸體忽然破棺而出澈段,到底是詐尸還是另有隱情悠菜,我是刑警寧澤,帶...
    沈念sama閱讀 34,270評論 4 329
  • 正文 年R本政府宣布败富,位于F島的核電站悔醋,受9級特大地震影響,放射性物質(zhì)發(fā)生泄漏兽叮。R本人自食惡果不足惜芬骄,卻給世界環(huán)境...
    茶點故事閱讀 39,867評論 3 312
  • 文/蒙蒙 一、第九天 我趴在偏房一處隱蔽的房頂上張望鹦聪。 院中可真熱鬧账阻,春花似錦、人聲如沸泽本。這莊子的主人今日做“春日...
    開封第一講書人閱讀 30,734評論 0 21
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽。三九已至蒲牧,卻和暖如春撇贺,著一層夾襖步出監(jiān)牢的瞬間,已是汗流浹背造成。 一陣腳步聲響...
    開封第一講書人閱讀 31,961評論 1 265
  • 我被黑心中介騙來泰國打工显熏, 沒想到剛下飛機就差點兒被人妖公主榨干…… 1. 我叫王不留,地道東北人晒屎。 一個月前我還...
    沈念sama閱讀 46,297評論 2 360
  • 正文 我出身青樓喘蟆,卻偏偏與公主長得像,于是被迫代替她去往敵國和親鼓鲁。 傳聞我的和親對象是個殘疾皇子蕴轨,可洞房花燭夜當(dāng)晚...
    茶點故事閱讀 43,472評論 2 348

推薦閱讀更多精彩內(nèi)容

  • 當(dāng)類實現(xiàn)接口時,接口就充當(dāng)可以引用這個類的實例的類型(type)骇吭。因此類實現(xiàn)了接口橙弱,就表明客戶端可以對這個類的實例...
    NekoJiang閱讀 676評論 0 0
  • 1. Java基礎(chǔ)部分 基礎(chǔ)部分的順序:基本語法,類相關(guān)的語法燥狰,內(nèi)部類的語法棘脐,繼承相關(guān)的語法,異常的語法龙致,線程的語...
    子非魚_t_閱讀 31,598評論 18 399
  • 枚舉類型是指由一組固定的常量組成合法值的類型蛀缝,例如一年中的季節(jié),太陽系中的行星或者一副牌中的花色目代。在編程語言...
    小小輝_710a閱讀 1,428評論 0 0
  • 對象的創(chuàng)建與銷毀 Item 1: 使用static工廠方法屈梁,而不是構(gòu)造函數(shù)創(chuàng)建對象:僅僅是創(chuàng)建對象的方法,并非Fa...
    孫小磊閱讀 1,965評論 0 3
  • 雖然用了“御用白衣天使”的專用配方榛了,我今天還是在床上度過大半天在讶,頭還有點暈痛感。 今天是戰(zhàn)友聚會日霜大,看到自己的狀態(tài)...
    D066有情人尋找紅辣椒佛山閱讀 301評論 2 3