<rt id="bn8ez"></rt>
<label id="bn8ez"></label>

  • <span id="bn8ez"></span>

    <label id="bn8ez"><meter id="bn8ez"></meter></label>

    posts - 89,  comments - 98,  trackbacks - 0

    在沒有好好地研習面向對象設計的設計模式之前,我對Java接口和Java抽象類的認識還是很模糊,很不可理解。

    剛學Java語言時,就很難理解為什么要有接口這個概念,雖說是可以實現所謂的多繼承,可一個只有方法名,沒有方法體的東西,我實現它又有什么用呢?我從它那什么也得不到,除了一些方法名,我直接在具體類里加入這些方法不就行了嗎?

    為什么一定要有抽象類這個概念?為什么就不能把這個父類寫成一個具體的類,子類再繼承它不就可以了嗎?何必弄一個抽象類出來,還要弄一些沒有方法體的抽象方法,弄得又象接口又象類的,讓人捉摸不定。

    當我開始學習java設計模式,真正走進面向對象設計的大門之后,我才發現,自己對面向對象設計的理解原來是那么的片面,那么的膚淺,根本就沒有真正理解面向對象思想的精髓,在某一種程度上還受著面向過程的影響,以為弄出了一個個類,就算是面向對象了,而其實還是被過程所驅使著。

    我還是說說我現在對面向對象思想的理解吧,不一定正確全面,但我想應該還算是比以前略有進步吧。

    面向對象思想,我覺得最關鍵的就是抽象。

    一個軟件設計的好壞,我想很大程度上取決于它的整體架構,而這個整體架構其實就是你對整個宏觀商業業務的抽象框架,當代表業務邏輯的高層抽象層結構合理時,你底層的具體實現需要考慮的就僅僅是一些算法和一些具體的業務實現了。當你需要再開發另一個相近的項目時,你以前的抽象層說不定還可以再次利用呢,面對對象的設計,復用的重點其實應該是抽象層的復用,而不是具體某一個代碼塊的復用,是不是一下子感覺自己對復用理解的高度又上升了一層?^_^

    說到了抽象,我就不能不提到曾讓我頭痛的Java接口和Java抽象類了,這也是本文我想說的重點。

    既然面向對象設計的重點在于抽象,那Java接口和Java抽象類就有它存在的必然性了。

    Java接口和Java抽象類代表的就是抽象類型,就是我們需要提出的抽象層的具體表現。OOP面向對象的編程,如果要提高程序的復用率,增加程序的可維護性,可擴展性,就必須是面向接口的編程,面向抽象的編程,正確地使用接口、抽象類這些太有用的抽象類型做為你結構層次上的頂層。

    Java接口和Java抽象類有太多相似的地方,又有太多特別的地方,究竟在什么地方,才是它們的最佳位置呢?把它們比較一下,你就可以發現了。

    1、Java接口和Java抽象類最大的一個區別,就在于Java抽象類可以提供某些方法的部分實現,而Java接口不可以,這大概就是Java抽象類唯一的優點吧,但這個優點非常有用。
    如果向一個抽象類里加入一個新的具體方法時,那么它所有的子類都一下子都得到了這個新方法,而Java接口做不到這一點,如果向一個Java接口里加入一個新方法,所有實現這個接口的類就無法成功通過編譯了,因為你必須讓每一個類都再實現這個方法才行,這顯然是Java接口的缺點。

    2、一個抽象類的實現只能由這個抽象類的子類給出,也就是說,這個實現處在抽象類所定義出的繼承的等級結構中,而由于Java語言的單繼承性,所以抽象類作為類型定義工具的效能大打折扣。
    在這一點上,Java接口的優勢就出來了,任何一個實現了一個Java接口所規定的方法的類都可以具有這個接口的類型,而一個類可以實現任意多個Java接口,從而這個類就有了多種類型。

    3、從第2點不難看出,Java接口是定義混合類型的理想工具,混合類表明一個類不僅僅具有某個主類型的行為,而且具有其他的次要行為。

    4、結合1、2點中抽象類和Java接口的各自優勢,具精典的設計模式就出來了:聲明類型的工作仍然由Java接口承擔,但是同時給出一個Java抽象類,且實現了這個接口,而其他同屬于這個抽象類型的具體類可以選擇實現這個Java接口,也可以選擇繼承這個抽象類,也就是說在層次結構中,Java接口在最上面,然后緊跟著抽象類,哈,這下兩個的最大優點都能發揮到極至了。這個模式就是“缺省適配模式”。
    在Java語言API中用了這種模式,而且全都遵循一定的命名規范:Abstract +接口名。

    Java接口和Java抽象類的存在就是為了用于具體類的實現和繼承的,如果你準備寫一個具體類去繼承另一個具體類的話,那你的設計就有很大問題了。Java抽象類就是為了繼承而存在的,它的抽象方法就是為了強制子類必須去實現的。

    使用Java接口和抽象Java類進行變量的類型聲明、參數是類型聲明、方法的返還類型說明,以及數據類型的轉換等。而不要用具體Java類進行變量的類型聲明、參數是類型聲明、方法的返還類型說明,以及數據類型的轉換等。

    我想,如果你編的代碼里面連一個接口和抽象類都沒有的話,也許我可以說你根本沒有用到任何設計模式,任何一個設計模式都是和抽象分不開的,而抽象與Java接口和抽象Java類又是分不開的。

    理解抽象,理解Java接口和抽象Java類,我想就應該是真正開始用面向對象的思想去分析問題,解決問題了吧

    posted on 2006-07-31 16:35 水煮三國 閱讀(709) 評論(2)  編輯  收藏 所屬分類: J2SE

    FeedBack:
    # re: java當中接口與抽象類的思考
    2006-07-31 16:36 | 水煮三國
    一個不錯的總結,使我受益非淺。  回復  更多評論
      
    # re: java當中接口與抽象類的思考
    2006-08-03 12:01 | kook
    恩,受益中,感謝  回復  更多評論
      
    <2006年7月>
    2526272829301
    2345678
    9101112131415
    16171819202122
    23242526272829
    303112345

    常用鏈接

    留言簿(4)

    隨筆分類(85)

    隨筆檔案(89)

    文章分類(14)

    文章檔案(42)

    收藏夾(37)

    java

    oracle

    Sybase

    搜索

    •  

    積分與排名

    • 積分 - 211659
    • 排名 - 266

    最新評論

    閱讀排行榜

    評論排行榜

    主站蜘蛛池模板: 免费人成在线观看视频播放| 午夜免费1000部| 国产一级淫片免费播放电影| 亚洲一区二区三区精品视频| 久久国产乱子伦免费精品| 亚洲国产精品一区二区久久| 久久99毛片免费观看不卡| 大桥未久亚洲无av码在线| 永久免费av无码不卡在线观看| 亚洲国产成人久久精品app| 1000部拍拍拍18勿入免费视频软件 | 国产高清在线免费视频| 亚洲成片观看四虎永久| 久久精品夜色国产亚洲av| 最新久久免费视频| 亚洲av无码一区二区三区网站| 高清一区二区三区免费视频| 亚洲精品中文字幕麻豆| 国产精品免费看久久久香蕉| 久久精品国产精品亚洲下载| 中文字幕无线码中文字幕免费| 青春禁区视频在线观看直播免费 | 亚洲爆乳无码专区www| 最近2019中文字幕免费直播 | 亚洲av日韩av高潮潮喷无码| 中文字幕在线免费| 亚洲日本中文字幕天天更新| 亚洲国产黄在线观看| 国产午夜无码精品免费看动漫| 67pao强力打造67194在线午夜亚洲| 97碰公开在线观看免费视频| 亚洲色大成网站www永久男同 | 亚洲成人国产精品| 亚洲免费视频网站| 亚洲成a人无码亚洲成www牛牛| 亚洲精品线路一在线观看| 久久国产乱子伦精品免费不卡| 亚洲影院天堂中文av色| 久久亚洲高清综合| 在线观看免费高清视频| 国产特黄特色的大片观看免费视频 |