久久亚洲精品成人_国产精品欧美综合亚洲_亚洲va天堂va欧美ⅴa在线_91色视频在线观看_久久影院亚洲_一级黄色片播放_日韩av在线一区_精品一区二区在线看_老头吃奶性行交视频_日韩免费高清视频_天天操天天爽天天干_日本欧美在线视频

首頁 > 編程 > Java > 正文

為什么Java中繼承多數是有害的

2020-03-24 18:52:34
字體:
來源:轉載
供稿:網友
大多數好的設計者象躲避瘟疫一樣來避免使用實現繼承(extends 關系)。實際上80%的代碼應該完全用interfaces寫,而不是通過extends。“Java設計模式”一書詳細闡述了怎樣用接口繼承代替實現繼承。這篇文章描述設計者為什么會這么作。

Extends是有害的;也許對于Charles Manson這個級別的不是,但是足夠糟糕的它應該在任何可能的時候被避開?!癑AVA設計模式”一書花了很大的部分討論用interface繼承代替實現繼承。

好的設計者在他的代碼中,大部分用interface,而不是具體的基類。本文討論為什么設計者會這樣選擇,并且也介紹一些基于interface的編程基礎。

接口(Interface)和類(Class)?

一次,我參加一個Java用戶組的會議。在會議中,Jams Gosling(Java之父)做發起人講話。在那令人難忘的Q&A部分中,有人問他:“如果你重新構造Java,你想改變什么?”。“我想拋棄html' target='_blank'>classes”他回答。在笑聲平息后,它解釋說,真正的問題不是由于class本身,而是實現繼承(extends) 關系。接口繼承(implements關系)是更好的。你應該盡可能的避免實現繼承。

失去了靈活性

為什么你應該避免實現繼承呢?第一個問題是明確的使用具體類名將你固定到特定的實現,給底層的改變增加了不必要的困難。

在當前的敏捷編程方法中,核心是并行的設計和開發的概念。在你詳細設計程序前,你開始編程。這個技術不同于傳統方法的形式----傳統的方式是設計應該在編碼開始前完成----但是許多成功的項目已經證明你能夠更快速的開發高質量代碼,相對于傳統的按部就班的方法。但是在并行開發的核心是主張靈活性。你不得不以某一種方式寫你的代碼以至于最新發現的需求能夠盡可能沒有痛苦的合并到已有的代碼中。

勝于實現你也許需要的特征,你只需實現你明確需要的特征,而且適度的對變化的包容。如果你沒有這種靈活,并行的開發,那簡直不可能。

對于Inteface的編程是靈活結構的核心。為了說明為什么,讓我們看一下當使用它們的時候,會發生什么。考慮下面的代碼:

f()
{
LinkedList list = new LinkedList();
//...
g( list );
}

g( LinkedList list )
{
list.add( ... );
g2( list )
}

假設一個對于快速查詢的需求被提出,以至于這個LinkedList不能夠解決。你需要用HashSet來代替它。在已有代碼中,變化不能夠局部化,因為你不僅僅需要修改f()也需要修改g()(它帶有LinkedList參數),并且還有g()把列表傳遞給的任何代碼。象下面這樣重寫代碼:

f()
{
Collection list = new LinkedList();
//...
g( list );
}

g( Collection list )
{
list.add( ... );
g2( list )
}

這樣修改Linked list成hash,可能只是簡單的用new HashSet()代替new LinkedList()。就這樣。沒有其他的需要修改的地方。

作為另一個例子,比較下面兩段代碼:

f()
{
Collection c = new HashSet();
//...
g( c );
}

g( Collection c )
{
for( Iterator i = c.iterator(); i.hasNext() )
do_something_with( i.next() );
}



f2()
{
Collection c = new HashSet();
//...
g2( c.iterator() );
}

g2( Iterator i )
{
while( i.hasNext() )
do_something_with( i.next() );
}


g2()方法現在能夠遍歷Collection的派生,就像你能夠從Map中得到的鍵值對。事實上,你能夠寫iterator,它產生數據,代替遍歷一個Collection。你能夠寫iterator,它從測試的框架或者文件中得到信息。這會有巨大的靈活性。

耦合

對于實現繼承,一個更加關鍵的問題是耦合---令人煩躁的依賴,就是那種程序的一部分對于另一部分的依賴。全局變量提供經典的例子,證明為什么強耦合會引起麻煩。例如,如果你改變全局變量的類型,那么所有用到這個變量的函數也許都被影響,所以所有這些代碼都要被檢查,變更和重新測試。而且,所有用到這個變量的函數通過這個變量相互耦合。也就是,如果一個變量值在難以使用的時候被改變,一個函數也許就不正確的影響了另一個函數的行為。這個問題顯著的隱藏于多線程的程序。

作為一個設計者,你應該努力最小化耦合關系。你不能一并消除耦合,因為從一個類的對象到另一個類的對象的方法調用是一個松耦合的形式。你不可能有一個程序,它沒有任何的耦合。然而,你能夠通過遵守OO規則,最小化一定的耦合(最重要的是,一個對象的實現應該完全隱藏于使用他的對象)。例如,一個對象的實例變量(不是常量的成員域),應該總是private。我意思是某段時期的,無例外的,不斷的。(你能夠偶爾有效地使用protected方法,但是protected實例變量是可憎的事)同樣的原因你應該不用get/set函數---他們對于是一個域公用只是使人感到過于復雜的方式(盡管返回修飾的對象而不是基本類型值的訪問函數是在某些情況下是由原因的,那種情況下,返回的對象類是一個在設計時的關鍵抽象)。

這里,我不是書生氣。在我自己的工作中,我發現一個直接的相互關系在我OO方法的嚴格之間,快速代碼開發和容易的代碼實現。無論什么時候我違反中心的OO原則,如實現隱藏,我結果重寫那個代碼(一般因為代碼是不可調試的)。我沒有時間重寫代碼,所以我遵循那些規則。我關心的完全實用?我對干凈的原因沒有興趣。 脆弱的基類問題

現在,讓我們應用耦合的概念到繼承。在一個用extends的繼承實現系統中,派生類是非常緊密的和基類耦合,當且這種緊密的連接是不期望的。設計者已經應用了綽號“脆弱的基類問題”去描述這個行為?;A類被認為是脆弱的是,因為你在看起來安全的情況下修改基類,但是當從派生類繼承時,新的行為也許引起派生類出現功能紊亂。你不能通過簡單的在隔離下檢查基類的方法來分辨基類的變化是安全的;而是你也必須看(和測試)所有派生類。而且,你必須檢查所有的代碼,它們也用在基類和派生類對象中,因為這個代碼也許被新的行為所打破。一個對于基礎類的簡單變化可能導致整個程序不可操作。

讓我們一起檢查脆弱的基類和基類耦合的問題。下面的類extends了Java的ArrayList類去使它像一個stack來運轉:

class Stack extends ArrayList
{
private int stack_pointer = 0;

public void push( Object article )
{
add( stack_pointer++, article );
}

public Object pop()
{
return remove( --stack_pointer );
}

public void push_many( Object[] articles )
{
for( int i = 0; i articles.length; ++i )
push( articles[i] );
}
}

甚至一個象這樣簡單的類也有問題。思考當一個用戶平衡繼承和用ArrayList的clear()方法去彈出堆棧時:

Stack a_stack = new Stack();
a_stack.push("1");
a_stack.push("2");
a_stack.clear();

這個代碼成功編譯,但是因為基類不知道關于stack指針堆棧的情況,這個stack對象當前在一個未定義的狀態。下一個對于push()調用把新的項放入索引2的位置。(stack_pointer的當前值),所以stack有效地有三個元素-下邊兩個是垃圾。(Java的stack類正是有這個問題,不要用它).

對這個令人討厭的繼承的方法問題的解決辦法是為Stack覆蓋所有的ArrayList方法,那能夠修改數組的狀態,所以覆蓋正確的操作Stack指針或者拋出一個例外。(removeRange()方法對于拋出一個例外一個好的候選方法)。

這個方法有兩個缺點。第一,如果你覆蓋了所有的東西,這個基類應該真正的是一個interface,而不是一個class。如果你不用任何繼承方法,在實現繼承中就沒有這一點。第二,更重要的是,你不能夠讓一個stack支持所有的ArrayList方法。例如,令人煩惱的removeRange()沒有什么作用。唯一實現無用方法的合理的途徑是使它拋出一個例外,因為它應該永遠不被調用。這個方法有效的把編譯錯誤成為運行錯誤。不好的方法是,如果方法只是不被定義,編譯器會輸出一個方法未找到的錯誤。如果方法存在,但是拋出一個例外,你只有在程序真正的運行時,你才能夠發現調用錯誤。

對于這個基類問題的一個更好的解決辦法是封裝數據結構代替用繼承。這是新的和改進的Stack的版本:

class Stack
{
private int stack_pointer = 0;
private ArrayList the_data = new ArrayList();

public void push( Object article )
{
the_data.add( stack_poniter++, article );
}

public Object pop()
{
return the_data.remove( --stack_pointer );
}

public void push_many( Object[] articles )
{
for( int i = 0; i o.length; ++i )
push( articles[i] );
}
}

到現在為止,一直都不錯,但是考慮脆弱的基類問題,我們說你想要在stack創建一個變量, 用它在一段周期內跟蹤最大的堆棧尺寸。一個可能的實現也許象下面這樣:

class Monitorable_stack extends Stack
{
private int high_water_mark = 0;
private int current_size;

public void push( Object article )
{
if( ++current_size high_water_mark )
high_water_mark = current_size;
super.push( article );
}

publish Object pop()
{
--current_size;
return super.pop();
}

public int maximum_size_so_far()
{
return high_water_mark;
}
}

這個新類運行的很好,至少是一段時間。不幸的是,這個代碼發掘了一個事實,push_many()通過調用push()來運行。首先,這個細節看起來不是一個壞的選擇。它簡化了代碼,并且你能夠得到push()的派生類版本,甚至當Monitorable_stack通過Stack的參考來訪問的時候,以至于high_water_mark能夠正確的更新。html教程

鄭重聲明:本文版權歸原作者所有,轉載文章僅為傳播更多信息之目的,如作者信息標記有誤,請第一時間聯系我們修改或刪除,多謝。

發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
污视频免费在线观看网站| 日韩女优av电影在线观看| 亚洲亚裔videos黑人hd| 精品国产区一区| 欧美日韩成人黄色| 精品视频第一区| 人妻巨大乳一二三区| 亚洲av无码一区二区三区在线| 国产日产精品一区二区三区| 国产乱色国产精品免费视频| 精品人妻伦一二三区久| 日本中文字幕网| 毛片一区二区三区| 亚洲电影一区二区| 欧美一级免费看| 亚洲精品一二三四五区| 一级片视频免费观看| 久久这里只有精品9| 亚洲男人天堂一区| 国产91精品不卡视频| 青娱乐91视频| 亚洲女同一区二区| 亚洲精品无码久久久久久| 国产精品熟女视频| 久久色在线观看| 日韩在线视频网站| 黄色www网站| 99er热精品视频| 国产成人综合自拍| www国产精品视频| www.超碰com| 97久久人国产精品婷婷| 亚洲久草在线视频| 日本在线一二三区| 日本福利一区二区| 免费精品视频一区| 亚洲人做受高潮| 国产精品久久夜| 国产成人在线一区二区| 少妇极品熟妇人妻无码| 99久久亚洲一区二区三区青草| 亚洲精品中文字| 亚洲欧洲日本精品| 欧美高清www午色夜在线视频| 亚洲国产精品日韩| 国产美女精品视频国产| 国产精品美女在线| 亚洲美女爱爱视频| 综合色天天鬼久久鬼色| 亚洲欧美国产另类| www.这里只有精品| 国产精品国产三级国产普通话99| 亚洲va久久久噜噜噜| 国产九色91回来了| 91系列在线观看| 99sesese| 高清欧美性猛交| 亚洲精品成人无码毛片| 精品88久久久久88久久久| aaa人片在线| 久久久久久久久久久久久女国产乱| 精品国产区一区二区三区在线观看 | 精品日韩在线视频| 亚洲欧洲日韩在线| 黄色在线观看av| 色哟哟亚洲精品| 亚洲国产精品三区| 一区二区国产精品视频| 亚洲图片另类小说| 欧美成人aa大片| 97人妻精品一区二区三区免| 午夜电影久久久| 成人蜜桃视频| 亚洲视频在线a| 亚洲无亚洲人成网站77777| 人人妻人人澡人人爽久久av| 久久久久久久激情视频| 国产无遮挡猛进猛出免费软件| 日韩久久久精品| 久久久久成人网站| 亚洲电影免费观看高清完整版在线观看 | 99国产精品欲| 99免费视频观看| 久久久久久综合网天天| 一区二区三区四区精品在线视频 | 国产同性人妖ts口直男| 成熟了的熟妇毛茸茸| 亚洲伦理在线精品| 免费又黄又爽又猛大片午夜| 久久精品国产99国产精品澳门| 国产香蕉在线视频| 最近中文字幕2019免费| 国产天堂亚洲国产碰碰| 黄页网站大全在线观看| 久久好看免费视频| 午夜在线电影亚洲一区| 久久精品三级| 久久综合一区二区三区| 亚洲欧美在线第一页| 三级影片在线看| 日本xxx免费| 亚洲欧美日韩三级| 欧美一区二区三区视频在线观看| 99999精品| 精品亚洲一区二区| 国产精品一区二区视频| 国产网址在线观看| 另类小说色综合| 日产国产精品精品a∨| 黄色一级大片在线免费看国产一 | 久久午夜精品视频| 久99久视频| 99国产麻豆精品| 欧美日韩激情视频在线观看| 欧美日韩国产影片| 精品午夜福利在线观看| 黄色在线视频网| 亚洲 国产 欧美一区| 丁香五精品蜜臀久久久久99网站 | 欧美精品一卡两卡| 国产精品成人一区二区艾草 | 欧美色电影在线| 天海翼在线视频| 天堂av2020| 日韩高清不卡av| 亚洲免费国产视频| 久久夜色精品| 久久久久久久久爱| 欧美成人一区二区三区片免费| 亚洲毛片av在线| 久久这里只有精品首页| 日韩中文字幕一区二区三区| 中文字幕在线综合| 国产女教师bbwbbwbbw| 无码精品人妻一区二区| 视频一区 中文字幕| 麻豆久久久av免费| 国产99在线播放| 成人久久精品视频| 亚洲欧美一区二区三区孕妇| 白白色免费视频| 国产农村妇女精品久久| 国产精品久久久久影院日本| 91精品国产成人www| 欧美视频中文在线看| 天天操天天舔天天干| 国产成人精品一区二区无码呦| 伊人av在线播放| 国产亚洲精品成人a| 中文字幕中文字幕在线中心一区 | 亚洲视频图片小说| 精品国产亚洲一区二区麻豆| 亚洲欧洲精品一区二区三区波多野1战4| 日韩中文第一页| 欧美一区二区大片| 国产精品蜜臀av| 蜜桃视频在线一区| 久久精品日产第一区二区三区精品版 | 免费在线观看的av网站| 精品成人私密视频| 不卡一卡二卡三乱码免费网站| 97在线精品视频| 亚洲国产视频一区二区三区| 国产精品无码免费专区午夜| 亚洲男人天堂一区| 亚洲在线视频播放| 欧美成人精品免费| 亚洲国产天堂久久综合网| 91成品人影院| 一级黄色大片儿| 国产精品拍拍拍| 天堂在线资源视频| 99热在线播放| 国产z一区二区三区| 国产成人免费电影| 亚洲免费视频播放| 亚欧激情乱码久久久久久久久| 亚洲天堂国产视频| 久久撸在线视频| www.黄色网| 天堂网av手机版| 中文字幕一区二区久久人妻| 国产淫片av片久久久久久| 国产乱肥老妇国产一区二| 在线区一区二视频| 一区二区三区不卡在线观看 | 亚洲国产日日夜夜| 亚洲丝袜美腿综合| 日韩欧美精品网站| 国产亚洲欧洲高清| 国产做受69高潮| 久久综合久久久| 色综合久久五月| 亚洲精品免费网站| 亚洲福利av| 欧美成人午夜精品免费| 黄色小视频免费在线观看| 中文子幕无线码一区tr| 久久99久久久久久久久久久| 90岁老太婆乱淫| 精品一区在线播放| 亚洲熟妇无码一区二区三区导航| 亚洲一区二区免费在线| 无遮挡又爽又刺激的视频| 国产亚洲第一页| 国产一区二区免费视频| 亚洲av中文无码乱人伦在线视色| 91成人在线观看喷潮教学| 国内自拍第二页| 一级黄色av片| 欧美日韩亚洲91| 亚洲一区二区精品久久av| 污视频软件在线观看| 黄色aaa大片| 欧美视频13p| 国产精品男女猛烈高潮激情| www.成年人| 99久久精品国产成人一区二区| 久久久高清一区二区三区| 一区二区三区视频在线| 屁屁影院ccyy国产第一页| 中文字幕 亚洲视频| 欧美日韩中国免费专区在线看| 久久精品国产v日韩v亚洲| 一区二区三区日韩视频| 噜噜噜噜噜久久久久久91| 中文字幕在线视频播放| 丁香六月久久综合狠狠色| 日韩av影院在线观看| 成人在线免费观看视视频| 欧美日韩一区二区区别是什么 | 爱福利视频一区| 少妇一级淫免费放| 国产剧情精品在线| 亚洲自拍另类综合| 成人在线看片| 自拍偷拍第八页| 精品黑人一区二区三区久久| 日本xxxx免费| proumb性欧美在线观看| 久久国产精品影视| 57pao成人永久免费视频| 中文字幕第4页| 亚洲精品老司机| 中文字幕在线精品| 久久天堂av综合合色| 国产精品久久久久久久9999 | 日本亚洲一区二区| 久久99国内精品| 波多野结衣一区二区三区| 国产精品久久久久久久天堂| 日韩人妻精品中文字幕| 自拍偷拍亚洲精品| 绯色av蜜臀vs少妇| 亚洲精品中文字幕在线观看| 日本一区二区免费看| 一级欧美一级日韩片| 亚洲视频一区二区在线观看| 国产精品永久免费在线| 91黑人精品一区二区三区| 亚洲护士老师的毛茸茸最新章节| 挪威xxxx性hd极品| 欧美性猛交丰臀xxxxx网站| 日韩aaaaa| a在线观看视频| 久久av.com| 丰满少妇xoxoxo视频| 中文精品99久久国产香蕉| 欧美一区二区三区久久久| 亚洲精品国产成人| 手机看片福利视频| 国产成人亚洲精品狼色在线| 国产综合18久久久久久| av最新在线观看| 一区二区欧美精品| 丝袜制服一区二区三区| 黑人巨大精品欧美一区二区三区| 欧美人与性动交α欧美精品| 亚洲аv电影天堂网| 色噜噜在线观看| 国产一区二区免费| 亚洲国产综合久久| 日韩av电影在线网| 少妇人妻好深好紧精品无码| 国产亚洲福利社区一区| 噜噜噜久久亚洲精品国产品麻豆| 99精品国产热久久91蜜凸| 精品一区2区三区| 中文字幕第一区综合| 欧美精品色视频| 色88888久久久久久影院野外 | 国产调教视频一区| 亚洲精品视频一二三| 亚洲日本丝袜连裤袜办公室| 免费不卡的av| 国产精品久久久久久久久免费看 | www.av88| 国产精品区一区二区三含羞草| 国产精品区在线| 欧美日本不卡视频| 色在线观看视频| 欧美色精品在线视频| 国产这里有精品| 色青青草原桃花久久综合| 黄色av免费观看| 日韩在线一级片| 亚洲精品自产拍| 成人app下载| 又色又爽的视频| 在线观看成人小视频| 中文字幕乱码在线观看| 欧美亚洲另类色图| 久久97精品久久久久久久不卡 | 999国内精品视频在线| 波多野结衣绝顶大高潮| 91精品国产综合久久香蕉的用户体验| 成年人晚上看的视频| 欧美精品在线一区| 亚洲av成人无码久久精品老人 | 毛片av免费在线观看| 社区色欧美激情 | 国产精品一色哟哟哟| 国产亚洲色婷婷久久99精品91| 欧美高清性xxxxhdvideosex| 欧美三级中文字幕在线观看| 囯产精品一品二区三区| 亚洲欧美高清在线| 视频一区二区在线| 永久免费看mv网站入口亚洲| 激情深爱一区二区| 欧洲中文字幕国产精品| 亚洲国产精品久久人人爱潘金莲| 亚洲美女精品视频| 国产精品久久激情| 日韩欧美视频一区| 国产精品入口麻豆原神| 国产99久一区二区三区a片| 99视频在线视频| 91视频九色网站| 欧美刺激脚交jootjob| 99re6这里只有精品视频在线观看 99re8在线精品视频免费播放 | 欧美性极品少妇精品网站| 亚洲av成人无码网天堂| www.四虎精品| 男女爱爱视频网站| 区一区二区三区中文字幕 | 在线观看免费黄色小视频| 久久久久亚洲av无码网站| 男人的天堂狠狠干| 都市激情久久久久久久久久久| 六月婷婷色综合| 狠狠狠狠狠狠狠| 中文字幕在线日本| 精品人妻无码一区| 亚洲午夜精品久久久久久浪潮| 最新国产精品久久精品| 国产麻豆视频精品| 亚洲精品男人天堂| 色一情一交一乱一区二区三区| 污污的视频免费观看| 日韩精品一区二区三区久久| 日本不卡在线观看| 国产精品网址在线| 久久久久久网站| 国产成人精品免费视频| 色与欲影视天天看综合网| 亚洲人成在线观看| 欧美大黄免费观看| 亚洲欧洲日产国产综合网| 国产一区二区三区在线看麻豆| 草草视频在线播放| 天堂免费在线视频| 五月天丁香社区| 久久人妻精品白浆国产| 黄色片一级视频| 色悠悠久久综合网| 日韩毛片在线免费看| 日韩av三级在线| 国产一级特黄a大片免费| www.午夜av| 国产xxxxxxxxx| 国产激情av在线| 免费又黄又爽又色的视频| 97中文字幕在线观看| 波多野结衣网页| av鲁丝一区鲁丝二区鲁丝三区| 国产中年熟女高潮大集合| 女同久久另类69精品国产| 91在线|亚洲| 国产精品对白一区二区三区| 日本不卡在线观看| 加勒比在线一区二区三区观看| 国产精品一区二区av| 日韩成人三级视频| 一级片黄色录像| 97超碰人人草| 成人免费三级在线| 亚洲国产精品尤物yw在线观看| 欧美女孩性生活视频| 亚洲精品中文字| 成人亚洲欧美一区二区三区| 日本一本二本在线观看| 免费黄色在线播放| 日韩不卡在线播放| 久久久久久综合| 欧美一区二区三区免费观看视频| 不卡av在线网站| 日本在线成人一区二区| 国产精品久久a| 无码人妻av免费一区二区三区 |