国产精品电影_久久视频免费_欧美日韩国产激情_成年人视频免费在线播放_日本久久亚洲电影_久久都是精品_66av99_九色精品美女在线_蜜臀a∨国产成人精品_冲田杏梨av在线_欧美精品在线一区二区三区_麻豆mv在线看

關于能提高Java代碼可重用性的三個措施

開發 后端
本文介紹的是java代碼可重用性方面的知識,主要介紹了三個方面,希望對你有幫助,一起來看。

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

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

通過類繼承實現代碼重用不是精確的代碼重用技術,因此它并不是最理想的代碼重用機制。換句話說,如果不繼承整個類的所有方法和數據成員,我們無法重用該類里面的單個方法。繼承總是帶來一些多余的方法和數據成員,它們總是使得重用類里面某個方法的代碼復雜化。

另外,派生類對父類的依賴關系也使得代碼進一步復雜化:對父類的改動可能影響子類;修改父類或者子類中的任意一個類時,我們很難記得哪一個方法被子類覆蓋、哪一個方法沒有被子類覆蓋;最后,子類中的覆蓋方法是否要調用父類中的對應方法有時并不顯而易見。

任何方法,只要它執行的是某個單一概念的任務,就其本身而言,它就應該是首選的可重用代碼。為了重用這種代碼,我們必須回歸到面向過程的編程模式,把類的實例方法移出成為全局性的過程。

為了提高這種過程的可重用性,過程代碼應該象靜態工具方法一樣編寫:它只能使用自己的輸入參數,只能調用其他全局性的過程,不能使用任何非局部的變量。這種對外部依賴關系的限制簡化了過程的應用,使得過程能夠方便地用于任何地方。當然,由于這種組織方式總是使得代碼具有更清晰的結構,即使是不考慮重用性的代碼也同樣能夠從中獲益。

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

例如,對于下面這個類:

以下是引用片段:

  1. class Polygon {   
  2. .   
  3. .   
  4. public int getPerimeter() {...}   
  5. public boolean isConvex() {...}   
  6. public boolean containsPoint(Point p) {...}   
  7. .   
  8. .   
  9. }  

 

我們可以把它改寫成:

以下是引用片段:

  1. class Polygon {   
  2. .   
  3. .   
  4. public int getPerimeter() {return pPolygon.computePerimeter(this);}   
  5. public boolean isConvex() {return pPolygon.isConvex(this);}   
  6. public boolean containsPoint(Point p) {return pPolygon.containsPoint(this, p);}   
  7. .   
  8. }  

 

其中,pPolygon是:

以下是引用片段:

  1. class pPolygon {   
  2. static public int computePerimeter(Polygon polygon) {...}   
  3. static public boolean isConvex(Polygon polygon) {...}   
  4. static public boolean   
  5. containsPoint(Polygon polygon, Point p) {...}   

 

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

在上面這個例子中,改動代碼的最終效果是使得應用Polygon功能的客戶代碼不必再從Polygon繼承。Polygon類的功能現在已經由pPolygon類以過程為單位提供。客戶代碼只使用自己需要的代碼,無需關心 Polygon類中自己不需要的功能。但它并不意味著在這種新式過程化編程中類的作用有所削弱。

恰恰相反,在組織和封裝對象數據成員的過程中,類起到了不可或缺的作用,而且正如本文接下來所介紹的,類通過多重接口實現多態性的能力本身也帶來了卓越的代碼重用支持。然而,由于用實例方法封裝代碼功能并不是首選的代碼重用手段,所以通過類繼承達到代碼重用和多態性支持也不是最理想的。

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

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

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

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

例如,假設有這樣一個全局靜態方法:

以下是引用片段:

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

 

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

以下是引用片段:

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

 

而Rectangular接口的定義是:

以下是引用片段:

  1. public interface Rectangular   
  2. {   
  3. Rectangle getBounds();   

 

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

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

以下是引用片段:

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

 

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

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

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

以下是引用片段:

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

 

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

以下是引用片段:

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

 

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

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

當我們需要象使用C語言中的函數指針一樣使用參數時,創建唯一的接口描述參數需求是最好的選擇。例如,假設有下面這個過程:

以下是引用片段:

  1. static public void sort(List list, SortComparison comp) {...}  

 

該方法運用參數中提供的比較對象comp,通過比較給定列表list中的對象排序list列表。sort對comp對象的唯一要求是要調用一個方法進行比較。因此,SortComparison應該是只帶有一個方法的接口:

以下是引用片段:

  1. public interface SortComparison {   
  2. boolean comesBefore(Object a, Object b);   
  3. }  

 

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

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

責任編輯:于鐵 來源: 互聯網
相關推薦

2009-06-23 14:18:00

Java代碼可重用性

2011-07-21 13:24:14

java

2024-01-03 08:00:00

Java軟件開發代碼

2023-10-17 07:23:00

Vue組件代碼

2023-06-15 09:02:14

Python模塊和包

2019-10-14 16:42:02

云安全云計算

2019-06-06 08:48:14

代碼函數編程語言

2012-07-05 09:10:15

2024-12-03 14:53:04

2018-01-10 21:31:26

2016-07-26 11:21:53

2015-07-01 15:27:06

云平臺VM高可用

2012-02-28 09:41:00

Linux管理效率技巧

2022-04-14 14:09:25

數據治理數字化轉型工具

2018-11-23 09:43:26

2021-08-11 08:47:31

SASE網絡安全零信任

2010-03-10 10:41:23

Linux管理效率

2023-10-17 09:19:34

開發Java

2023-04-10 15:37:59

云計算云的部署

2024-06-28 01:13:59

工具C#代碼
點贊
收藏

51CTO技術棧公眾號

三上悠亚在线观看二区| 欧美一区高清| 在线国产亚洲欧美| 天堂资源在线观看| 久久久久久久免费视频了| 亚洲精品日韩成人| 亚洲黄色视屏| 都市激情久久久久久久久久久| 久久综合社区| 国语自产精品视频在线看抢先版图片| 青青热久免费精品视频在线18| 亚洲成人久久电影| 性网站在线观看| 欧美疯狂做受xxxx富婆| aaa日本高清在线播放免费观看| 午夜精品久久久久久久| 日本我和搜子同居的日子高清在线| 国产三级精品三级在线专区| 久久视频这里有精品| 国产91富婆露脸刺激对白| 黄色网在线视频| 成人精品视频一区| 无码aⅴ精品一区二区三区浪潮 | 911精品国产一区二区在线| 国产三级在线免费观看| 日韩欧美亚洲范冰冰与中字| 亚洲国产日韩欧美在线观看| 三级一区在线视频先锋 | av不卡高清| 在线播放中文字幕一区| 天堂√中文最新版在线| 欧美午夜精品久久久久久久| 日韩在线欧美在线国产在线| 欧美日韩高清免费| 图片一区二区| 香蕉乱码成人久久天堂爱免费| 超碰97人人在线| 五月天电影免费在线观看一区| 国产在线观看91一区二区三区| 欧美极品少妇xxxxⅹ高跟鞋| 色妞久久福利网| 婷婷丁香六月天| 热久久久久久久| 欧美日韩精品电影| 亚洲色成人一区二区三区小说| 国产一区二区三区四区五区| 视频精品在线观看| 中文字幕欧美日韩va免费视频| www.亚洲高清| 国产精品午夜一区二区三区| 日韩高清中文字幕一区| 国产精品久久久久影院日本| 嫩草影院国产精品| 一区二区三区四区日韩| 久久久久久久久久久亚洲| 久久97精品| 国产91精品网站| 韩国一区二区三区在线观看| 午夜视频久久久| 国产精品日日摸夜夜摸av| 免费人成在线观看网站| 日韩成人免费视频| 欧美视频三区| av资源站久久亚洲| 成人午夜免费视频| 最近最好的中文字幕2019免费| 日韩一级免费观看| 日韩精品一区二区三区中文| 亚洲一区二区三区成人在线视频精品| 日韩黄色免费电影| а√最新版在线天堂| 精品99一区二区三区| 最新精品国偷自产在线| 水蜜桃亚洲一二三四在线| 亚洲欧洲成人自拍| 高清电影在线免费观看| 日韩av电影国产| 国产精品66部| 四虎成人免费在线| 欧美人与性动交| 日韩国产在线一| 在线中文视频| 欧美精品一区二区免费| 夜久久久久久| 国产一区亚洲二区三区| 6080亚洲精品一区二区| 亚洲欧洲av| 妞干网在线观看视频| 欧美三片在线视频观看| 国产精品一区二区三区美女| 日韩精品一区二区三区色偷偷| 亚洲午夜精品久久久久久久久| 人人鲁人人莫人人爱精品| 国产精品国产三级国产专区53| 国产日韩欧美精品在线| 悠悠资源网亚洲青| 9a蜜桃久久久久久免费| 欧美激情一区二区三区| av在线不卡免费| 91精品国产一区二区三区动漫| 国产精品网曝门| 欧美日韩123区| 美女黄毛**国产精品啪啪| 亚洲女厕所小便bbb| 日韩大陆av| 午夜午夜精品一区二区三区文| 亚洲一级一区| 性色av一区| 日韩成人av在线播放| 国产精品igao视频网网址不卡日韩| 亚洲理论在线观看| 欧美影视资讯| 久久久一本精品99久久精品66| 国产精品免费免费| 欧美大片1688| 午夜欧美一区二区三区免费观看| 日韩欧美一区视频| 日韩美脚连裤袜丝袜在线| 最新国产精品久久| 欧美一区二区三区四区高清 | 91在线视频免费91| a'aaa级片在线观看| 国产成人精品福利一区二区三区| 亚洲在线观看免费| 色婷婷精品视频| wwwav91| 91国产高清在线| 久久丝袜美腿综合| 成人免费91| 欧美国产视频一区| 亚洲欧美另类人妖| 国产精品一区二区在线观看不卡 | 成人激情免费网站| 草草视频在线| 精品毛片久久久久久| xvideos亚洲人网站| 欧美激情一区在线| 国产在线激情视频| 欧美日韩你懂得| 午夜精品视频| 国产毛片在线看| 国产精品嫩草在线观看| 色综合天天性综合| 精品成人国产| porn视频在线观看| 国产精品一区二区三区在线观| 色婷婷久久久久swag精品| 精品国产不卡| 欧美91精品久久久久国产性生爱| 97人摸人人澡人人人超一碰| 91激情在线视频| 久久人人精品| 美女100%一区| 99视频精品免费| 国产精品久久久久久久7电影| 国产精品久线在线观看| 视频福利一区| 日本人妖在线| 国产精品久久久久久久久久久久冷 | 神马电影久久| 亚洲国产资源| 精品国产一区二区三区麻豆小说| 欧美性猛片aaaaaaa做受| 激情欧美一区| 超级碰碰不卡在线视频| 欧美精品久久久久久久自慰 | 欧美国产欧美综合| 日韩久久精品| a免费在线观看| 黄色网在线视频| 欧美尤物巨大精品爽| 色视频欧美一区二区三区| 日韩在线一二三区| 96视频在线观看欧美| 超碰影院在线| 正在播放91九色| 国内精品小视频| 欧美日韩一二区| av电影天堂一区二区在线观看| 美女久久99| wwwwxxxx在线观看| 男女午夜网站| 日韩高清av| 欧美日韩成人在线一区| 国产精品一区二区三区乱码| 欧洲亚洲视频| 丝袜国产在线| 成熟亚洲日本毛茸茸凸凹| 国产精品a久久久久| 人狥杂交一区欧美二区| 国产精品美女在线播放| 亚洲第一主播视频| 久久精品卡一| 一区二区三区| 欧美精品少妇| 欧美 日韩精品| 日韩欧美激情一区二区| 日韩免费观看av| 国产午夜精品视频| 欧美日韩国产色|