亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频

? 歡迎來到蟲蟲下載站! | ?? 資源下載 ?? 資源專輯 ?? 關于我們
? 蟲蟲下載站

?? 提高java代碼可重用性的三個.txt

?? 499篇java文章
?? TXT
字號:
作者:Eazily
email: Eazily@yeah.net
日期:2001-7-14 21:37:38
提高Java代碼可重用性的三個措施 

本文介紹了三種修改現有代碼提高其可重用性的方法,它們分別是:改寫類的實例方法,把參數類型改成接口,選擇最簡單的參數接口類型。 

措施一:改寫類的實例方法 

通過類繼承實現代碼重用不是精確的代碼重用技術,因此它并不是最理想的代碼重用機制。換句話說,如果不繼承整個類的所有方法和數據成員,我們無法重用該類里面的單個方法。繼承總是帶來一些多余的方法和數據成員,它們總是使得重用類里面某個方法的代碼復雜化。另外,派生類對父類的依賴關系也使得代碼進一步復雜化:對父類的改動可能影響子類;修改父類或者子類中的任意一個類時,我們很難記得哪一個方法被子類覆蓋、哪一個方法沒有被子類覆蓋;最后,子類中的覆蓋方法是否要調用父類中的對應方法有時并不顯而易見。 

任何方法,只要它執行的是某個單一概念的任務,就其本身而言,它就應該是首選的可重用代碼。為了重用這種代碼,我們必須回歸到面向過程的編程模式,把類的實例方法移出成為全局性的過程。為了提高這種過程的可重用性,過程代碼應該象靜態工具方法一樣編寫:它只能使用自己的輸入參數,只能調用其他全局性的過程,不能使用任何非局部的變量。這種對外部依賴關系的限制簡化了過程的應用,使得過程能夠方便地用于任何地方。當然,由于這種組織方式總是使得代碼具有更清晰的結構,即使是不考慮重用性的代碼也同樣能夠從中獲益。 

在Java中,方法不能脫離類而單獨存在。為此,我們可以把相關的過程組織成為獨立的類,并把這些過程定義為公用靜態方法。 

例如,對于下面這個類: 
class Polygon { 
. 
. 
public int getPerimeter() {...} 
public boolean isConvex() {...} 
public boolean containsPoint(Point p) {...} 
. 
. 
} 

我們可以把它改寫成: 
class Polygon { 
. 
. 
public int getPerimeter() {return pPolygon.computePerimeter(this);} 
public boolean isConvex() {return pPolygon.isConvex(this);} 
public boolean containsPoint(Point p) {return pPolygon.containsPoint(this, 
p 
);} 
. 

} 

其中,pPolygon是: 
class pPolygon { 
static public int computePerimeter(Polygon polygon) {...} 
static public boolean isConvex(Polygon polygon) {...} 
static public boolean 
containsPoint(Polygon polygon, Point p) {...} 
} 

從類的名字pPolygon可以看出,該類所封裝的過程主要與Polygon類型的對象有關。名字前面的p表示該類的唯一目的是組織公用靜態過程。在Java中,類的名字以小寫字母開頭是一種非標準的做法,但象pPloygon這樣的類事實上并不提供普通Java類的功能。也就是說,它并不代表著一類對象,它只是Java語言組織代碼的一種機制。 

在上面這個例子中,改動代碼的最終效果是使得應用Polygon功能的客戶代碼不必再從Polygon繼承。Polygon類的功能現在已經由pPolygon類以過程為單位提供??蛻舸a只使用自己需要的代碼,無需關心Polygon類中自己不需要的功能。但它并不意味著在這種新式過程化編程中類的作用有所削弱。恰恰相反,在組織和封裝對象數據成員的過程中,類起到了不可或缺的作用,而且正如本文接下來所介紹的,類通過多重接口實現多態性的能力本身也帶來了卓越的代碼重用支持。然而,由于用實例方法封裝代碼功能并不是首選的代碼重用手段,所以通過類繼承達到代碼重用和多態性支持也不是最理想的。 

措施二:把參數類型改成接口 

正如Allen Holub在《Build User Interfaces for Object-Oriented Systems》中所指出的,在面向對象編程中,代碼重用真正的要點在于通過接口參數類型利用多態性,而不是通過類繼承: 

“……我們通過對接口而不是對類編程達到代碼重用的目的。如果某個方法的所有參數都是對一些已知接口的引用,那么這個方法就能夠操作這樣一些對象:當我們編寫方法的代碼時,這些對象的類甚至還不存在。從技術上說,可重用的是方法,而不是傳遞給方法的對象?!?

在“措施一”得到的結果上應用Holub的看法,當某塊代碼能夠編寫為獨立的全局過程時,只要把它所有類形式的參數改為接口形式,我們就可以進一步提高它的可重用能力。經過這個改動之后,過程的參數可以是實現了該接口的所有類的對象,而不僅僅是原來的類所創建的對象。由此,過程將能夠對可能存在的大量的對象類型進行操作。 

例如,假設有這樣一個全局靜態方法: 
static public boolean contains(Rectangle rect, int x, int y) {...} 

這個方法用于檢查指定的點是否包含在矩形里面。在這個例子中,rect參數的類型可以從Rectangle類改變為接口類型,如下所示: 

static public boolean contains(Rectangular rect, int x, int y) {...} 

而Rectangular接口的定義是: 

public interface Rectangular {Rectangle getBounds();} 

現在,所有可以描述為矩形的類(即,實現了Rectangular接口的類)所創建的對象都可以作為提供給pRectangular.contains()的rect參數。通過放寬參數類型的限制,我們使方法具有更好的可重用性。 

不過,對于上面這個例子,Rectangular接口的getBounds方法返回Rectangle,你可能會懷疑這么做是否真正值得。換言之,如果我們知道傳入過程的對象會在被調用時返回一個Rectangle,為什么不直接傳入Rectangle取代接口類型呢?之所以不這么做,最重要的原因與集合有關。讓我們假設有這樣一個方法: 

static public boolean areAnyOverlapping(Collection rects) {...} 

該方法用于檢查給定集合中的任意矩形對象是否重疊。在這個方法的內部,當我們用循環依次訪問集合中的各個對象時,如果我們不能把對象cast成為Rectangular之類的接口類型,又如何能夠訪問對象的矩形區域呢?唯一的選擇是把對象cast成為它特有的類形式(我們知道它有一個方法可以返回矩形),它意味著方法必須事先知道它所操作的對象類型,從而使得方法的重用只限于那幾種對象類型。而這正是前面這個措施力圖先行避免的問題! 

措施三:選擇最簡單的參數接口類型 

在實施第二個措施時,應該選用哪一種接口類型來取代給定的類形式?答案是哪一個接口完全滿足過程對參數的需求,同時又具有最少的多余代碼和數據。描述參數對象要求的接口越簡單,其他類實現該接口的機會就越大——由此,其對象能夠作為參數使用的類也越多。從下面這個例子可以很容易地看出這一點: 

static public boolean areOverlapping(Window window1, Window window2) {...} 

這個方法用于檢查兩個窗口(假定是矩形窗口)是否重疊。如果這個方法只要求從參數獲得兩個窗口的矩形坐標,此時相應地簡化這兩個參數是一種更好的選擇: 

static public boolean areOverlapping(Rectangular rect1, Rectangular rect2) 
{ 
...} 

上面的代碼假定Window類型實現了Rectangular接口。經過改動之后,對于任何矩形對象我們都可以重用該方法的功能。 

有些時候可能會出現描述參數需求的接口擁有太多方法的情況。此時,我們應該在全局名稱空間中定義一個新的公共接口供其他面臨同一問題的代碼重用。 

當我們需要象使用C語言中的函數指針一樣使用參數時,創建唯一的接口描述參數需求是最好的選擇。例如,假設有下面這個過程: 
static public void sort(List list, SortComparison comp) {...} 

該方法運用參數中提供的比較對象comp,通過比較給定列表list中的對象排序list列表。sort對comp對象的唯一要求是要調用一個方法進行比較。因此,SortComparison應該是只帶有一個方法的接口: 
public interface SortComparison { 
boolean comesBefore(Object a, Object b); 
} 

SortComparison接口的唯一目的在于為sort提供一個它所需功能的鉤子,因此SortComparison接口不能在其他地方重用。 

總而言之,本文三個措施適合于改造現有的、按照面向對象慣例編寫的代碼。這三個措施與面向對象編程技術結合就得到了一種可在以后編寫代碼時使用的新式代碼編寫技術,它能夠簡化方法的復雜性和依賴關系,同時提高方法的可重用能力和內部凝聚力。 

當然,這里的三個措施不能用于那些天生就不適合重用的代碼。不適合重用的代碼通常出現在應用的表現層。例如,創建程序用戶界面的代碼,以及聯結到輸入事件的控制代碼,都屬于那種在程序和程序之間千差萬別的代碼,這種代碼幾乎不可能重

?? 快捷鍵說明

復制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
偷拍自拍另类欧美| 一区二区三区中文字幕电影| 久久99精品久久久久久国产越南| 制服丝袜中文字幕一区| 亚洲综合一区二区三区| 欧美高清视频不卡网| 日韩不卡手机在线v区| 日韩欧美亚洲国产另类| 国产一区二区三区av电影| 国产亚洲精久久久久久| 99视频精品全部免费在线| 亚洲综合无码一区二区| 91精品国产综合久久小美女| 久久av资源网| 中文字幕综合网| 欧美乱熟臀69xxxxxx| 韩国三级中文字幕hd久久精品| 国产日韩精品一区二区三区| 色综合色狠狠综合色| 三级一区在线视频先锋| 国产日韩欧美综合一区| 91免费小视频| 日韩极品在线观看| 国产三级三级三级精品8ⅰ区| 99久久婷婷国产综合精品 | 国产一区二区在线电影| 欧美激情一区二区三区蜜桃视频| 日本高清成人免费播放| 精一区二区三区| 亚洲天堂中文字幕| 欧美一卡二卡在线| 国产成人午夜精品5599| 亚洲第一电影网| 久久久久久97三级| 欧美午夜精品电影| 国产福利一区二区三区视频| 亚洲一卡二卡三卡四卡无卡久久| 精品国产乱码久久久久久闺蜜| 不卡av电影在线播放| 久久国产人妖系列| 亚洲精品日日夜夜| 国产丝袜在线精品| 欧美一区二区在线不卡| 99re视频精品| 国产高清不卡一区| 日本一区中文字幕| 亚洲精品美国一| 国产日韩欧美不卡在线| 欧美一区二区三区日韩视频| 一本一道综合狠狠老| 国产精品亚洲第一区在线暖暖韩国| 亚洲一二三四区| 中文字幕在线一区免费| 精品欧美一区二区三区精品久久| 欧美熟乱第一页| jizzjizzjizz欧美| 国产乱人伦偷精品视频不卡| 日本va欧美va精品发布| 一区二区三区精品在线| 国产精品国产馆在线真实露脸| 日韩精品一区国产麻豆| 欧美日韩国产精品成人| 色综合激情五月| 成人黄色综合网站| 国产精品亚洲成人| 久久精品99国产精品| 日韩福利视频导航| 亚洲成人免费影院| 亚洲成人1区2区| 亚洲国产欧美一区二区三区丁香婷| 国产精品区一区二区三区| 久久亚洲精品小早川怜子| 欧美大胆一级视频| 日韩免费观看高清完整版| 91精品国产综合久久国产大片| 欧美做爰猛烈大尺度电影无法无天| 99国产精品久久久久| eeuss影院一区二区三区| 成人av在线播放网址| 成人永久免费视频| 国产99精品视频| jvid福利写真一区二区三区| a美女胸又www黄视频久久| 不卡的av网站| 在线观看亚洲精品| 欧美久久高跟鞋激| 欧美高清hd18日本| 日韩一区二区在线播放| 精品剧情v国产在线观看在线| 精品日韩一区二区三区| 久久精品亚洲精品国产欧美| 国产精品午夜在线观看| 亚洲欧美另类久久久精品2019| 亚洲一区二区三区四区五区中文| 亚洲成人先锋电影| 久久se精品一区二区| 国产mv日韩mv欧美| 91小视频在线观看| 在线观看亚洲a| 日韩欧美三级在线| 日本一区二区三级电影在线观看 | 中文字幕中文字幕一区二区| 亚洲尤物视频在线| 全部av―极品视觉盛宴亚洲| 精品一区二区三区久久| 99精品久久99久久久久| 欧美人妖巨大在线| 久久人人超碰精品| 亚洲欧美日韩久久| 日韩黄色在线观看| 国产精品伊人色| 欧美在线|欧美| 精品日韩99亚洲| 亚洲乱码国产乱码精品精98午夜| 亚洲午夜精品在线| 国产乱子伦视频一区二区三区 | 国产精品家庭影院| 五月天激情小说综合| 国产精品亚洲一区二区三区妖精 | 欧美精品xxxxbbbb| 国产片一区二区| 日韩精品国产精品| www.亚洲激情.com| 欧美电影免费观看高清完整版在线 | 欧美亚洲国产怡红院影院| 精品福利av导航| 亚洲国产美女搞黄色| 夫妻av一区二区| 日韩精品中文字幕一区二区三区| 国产精品理论片| 久久99精品一区二区三区三区| 色素色在线综合| 精品国产成人系列| 天天综合网天天综合色| 91麻豆精品秘密| 久久久精品免费网站| 天天色综合天天| 色香色香欲天天天影视综合网| 久久精品水蜜桃av综合天堂| 日韩精品一区第一页| 91久久免费观看| 国产精品久久久久久久裸模| 激情综合五月天| 欧美日韩精品综合在线| 亚洲欧洲日韩在线| 国产精品亚洲综合一区在线观看| 欧美精品乱码久久久久久| 亚洲人成亚洲人成在线观看图片| 国产一区二区三区在线观看免费视频 | 2021久久国产精品不只是精品| 亚洲午夜电影在线观看| 91影视在线播放| 国产精品久久二区二区| 国产不卡在线视频| 久久中文娱乐网| 国产一区二区三区久久久| 欧美电视剧免费全集观看| 日本强好片久久久久久aaa| 欧美日韩一级二级三级| 亚洲一区二区三区小说| 欧美性猛交xxxxxx富婆| 亚洲精品免费一二三区| 99re亚洲国产精品| 亚洲欧美另类在线| 色偷偷成人一区二区三区91| 亚洲美腿欧美偷拍| 在线观看av一区| 午夜欧美大尺度福利影院在线看| 欧美吻胸吃奶大尺度电影| 亚洲小说春色综合另类电影| 欧美日韩情趣电影| 日韩精品欧美精品| 欧美一区二区三区四区久久| 奇米一区二区三区av| 日韩欧美国产wwwww| 国产精品77777竹菊影视小说| 国产午夜亚洲精品羞羞网站| 成人精品国产福利| 亚洲精品国产一区二区精华液 | 久久影院午夜论| 国产高清无密码一区二区三区| 国产精品视频一二三区| 成人深夜在线观看| 亚洲免费av观看| 欧美怡红院视频| 久久国产尿小便嘘嘘| 中文字幕不卡的av| 在线观看精品一区| 男女视频一区二区| 国产欧美精品在线观看| 在线亚洲一区二区| 蜜桃视频一区二区| 欧美激情自拍偷拍| 欧美影院一区二区三区| 久久99精品久久只有精品| 国产精品二三区| 欧美日韩国产大片| 国产精品亚洲专一区二区三区| 亚洲欧美日韩国产一区二区三区 | 中文字幕在线不卡一区|