OOAD 板


LINE

: tinlans 說的沒有錯,物件導向並不是要我們做無意義的繼承,但是物件導向也沒有 : 說一定要套封裝、繼承、多型。 : 光就「物件導向」這四個字的意義只是以「物件」為基礎來模擬 (Model) 真實世界的 : 東西,所以物件導向的分析第一步就是找出有哪些「物件」要被建立,儘管這個例子 : 簡單到物件少到只有兩三種:河內塔、盤子、或者柱子,但是這個問題是做練習還是 : 無意義什麼的我不管,在這邊就是討論如何以「物件」的角度來設計這樣的一個軟體。 基本上最古典的 OOP 定義就是指封裝、繼承、多型, 而僅有封裝這類, 一般被稱為 Object-based Programming 或 ADT programming, 它的設計精神與 OOP 差別就在於繼承和多型, 實際上它們的目的也有所不同; 以這個題目為例子, OOP 可以說是幾乎派不上用場, 事實上它也沒有必要派上用場, 套 ADT 就可以搞定, 甚至傳統的 procedural 就很足夠了; 這些狀況也是為什麼某語言很堅持支援 multi-paradigm, 而不要變成一個純 OOPL 的原因之一。 以最後寫出的程式來看, 如果不含繼承與多型, 我們只能說它是「以物件為基礎」設計而成的, 也就是 object-based 或 ADT。 : 在找出所有要被建立的「物件」之後,下一步就是找出每個物件之間的關係。當您了解 : 每個物件之間如何交流互動之後,才有辦法決定「物件」擁有哪些「成員」,而這些「 : 成員」也就是所謂的「屬性」和「方法」,儘管這個例子簡單到有些物件可能連一個「 : 方法」都沒有,但是河內塔擺明了就是在做練習而已,我儘可能地描述「物件導向」的 : 精神在哪邊,它是以何種思維來開發軟體的,如此而已。 這段做法事實上在 ADT 的年代就存在了, 只是大部分的教科書故意舉了 well-known 的東西, 譬如 stack 和 queue 之類的, 它們的定義已眾所皆知, 所以教科書直接將它們的定義當作 spec, 然後說明怎樣怎樣弄就會符合 ADT 的要求; 如果一個人的 knowledge 裡面並沒有 stack、queue、list 這些東西, 那麼他們找尋一個功能與之相同的物件所擁有的屬性和操作, 過程其實就是這樣子的, 而為它們設置一個名詞以及詳列規格 (也就是定義) 則是後來的事。 : 話說回來,河內塔問題用一個函式 (function) 就可以解決,它的複雜度低到不適合用 : 物件導向來模擬 (Model) 每個物件,它的所有變化也只有柱子的數目和盤子的數目,這 : 兩個變數的改變並不會使河內塔的問題用物件導向就比較好解決,所以真正要解決河內 : 塔問題的話,還是建議寫成一個函式就足夠了! 所以我覺得, 如果出這題目的是老師, 這位老師可能並不是一位很理想的教師, 如果是自己給自己練習的, 那麼建議是換個題目比較好; 物件導向的用意是程式碼再利用、應付多變的需求等等, 並不適合用在這種 case。 -- Ling-hua Tseng ([email protected]) Department of Computer Science, National Tsing-Hua University Interesting: C++, Compiler, PL/PD, OS, VM, Large-scale software design Researching: Software pipelining for VLIW architectures Homepage: https://it.muds.net/~uranus --



※ 發信站: 批踢踢實業坊(ptt.cc)
◆ From: 61.230.221.133 ※ 編輯: tinlans 來自: 61.230.221.133 (04/08 02:12)
1F:推 king19880326:感謝@@ 04/09 22:23







like.gif 您可能會有興趣的文章
icon.png[問題/行為] 貓晚上進房間會不會有憋尿問題
icon.pngRe: [閒聊] 選了錯誤的女孩成為魔法少女 XDDDDDDDDDD
icon.png[正妹] 瑞典 一張
icon.png[心得] EMS高領長版毛衣.墨小樓MC1002
icon.png[分享] 丹龍隔熱紙GE55+33+22
icon.png[問題] 清洗洗衣機
icon.png[尋物] 窗台下的空間
icon.png[閒聊] 双極の女神1 木魔爵
icon.png[售車] 新竹 1997 march 1297cc 白色 四門
icon.png[討論] 能從照片感受到攝影者心情嗎
icon.png[狂賀] 賀賀賀賀 賀!島村卯月!總選舉NO.1
icon.png[難過] 羨慕白皮膚的女生
icon.png閱讀文章
icon.png[黑特]
icon.png[問題] SBK S1安裝於安全帽位置
icon.png[分享] 舊woo100絕版開箱!!
icon.pngRe: [無言] 關於小包衛生紙
icon.png[開箱] E5-2683V3 RX480Strix 快睿C1 簡單測試
icon.png[心得] 蒼の海賊龍 地獄 執行者16PT
icon.png[售車] 1999年Virage iO 1.8EXi
icon.png[心得] 挑戰33 LV10 獅子座pt solo
icon.png[閒聊] 手把手教你不被桶之新手主購教學
icon.png[分享] Civic Type R 量產版官方照無預警流出
icon.png[售車] Golf 4 2.0 銀色 自排
icon.png[出售] Graco提籃汽座(有底座)2000元誠可議
icon.png[問題] 請問補牙材質掉了還能再補嗎?(台中半年內
icon.png[問題] 44th 單曲 生寫竟然都給重複的啊啊!
icon.png[心得] 華南紅卡/icash 核卡
icon.png[問題] 拔牙矯正這樣正常嗎
icon.png[贈送] 老莫高業 初業 102年版
icon.png[情報] 三大行動支付 本季掀戰火
icon.png[寶寶] 博客來Amos水蠟筆5/1特價五折
icon.pngRe: [心得] 新鮮人一些面試分享
icon.png[心得] 蒼の海賊龍 地獄 麒麟25PT
icon.pngRe: [閒聊] (君の名は。雷慎入) 君名二創漫畫翻譯
icon.pngRe: [閒聊] OGN中場影片:失蹤人口局 (英文字幕)
icon.png[問題] 台灣大哥大4G訊號差
icon.png[出售] [全國]全新千尋侘草LED燈, 水草

請輸入看板名稱,例如:WOW站內搜尋

TOP