Re: 物件導向的缺點 ??

看板OOAD作者 (畫畫狐)時間16年前 (2008/10/10 00:37), 編輯推噓5(501)
留言6則, 4人參與, 最新討論串12/13 (看更多)
※ 引述《legnaleurc (CA)》之銘言: : : 推 thinkniht :"過度疊床架屋"?什麼意思啊?看不懂=.=+ 07/14 18:47 : : 推 cplusplus :過度抽象化? 07/17 07:55 : : 推 H45 :疊床架屋,私以為是動態連結的意思。 07/17 09:17 : : 推 JustinHere :一層包一層,層層抽象化。。XD 07/20 22:41 : 就是過度抽象化的意思 : 以下舉一個很極端的例子: : 需求是寫一個九九乘法表 我可以再舉一個例子 像是一般常見的 Web 查詢程式 丟個SQL到後端DB把資料撈出來, 顯示在螢幕上 幾十行就可以寫完 如果要物件導向的話 也許要有個物件對應 Db Table 再來個物件處理SQL 如果你是會計資料的話, 可能要有個物件代表會計科目 如果是庫存資料的話, 可能要有個物件代表庫存商品 然後再套個MVC架構, Model 物件, 控制物件, 顯示物件 需求都一樣啊, 顯示出來的畫面也都一樣啊 但是這種OO設計的結果, 就會讓你多花不少的工時 使用者/客戶/老闆才不會管你那麼多, 只會問你為什麼某某只花一天寫好, 你要花二天 當然你可以想...哼哼, 我的程式俱備了OO的彈性, 不但好修改, 好替換, 而且還可以 Reuse 物件, 等到下次要寫其他類似的程式, 或是要修改時, 你們就知道了 過了不久, 果然要修改了 使用者要求要把欄位的字型變大, 呵呵, 只要改顯示物件就好了, 資料物件, Model.. 都不用修改 再過幾天, 使用者要求要多一個欄位, 而且這個欄位要從另一個Table join 進來, 你 忽然覺得有點不妙 多個欄位, 那當然要改顯示物件啊; 那資料哪裡來, 從SQL來啊, 所以和SQL有關的物件 也要改; 如果是MVC架構的話, Model和顯示都要改, 控制物件完全不用改嗎? 你之前 設計的會計科目物件, 或是庫存商品物件, 若因此要增加一個或多個屬性或方法, 能不 改嗎....不要忘了在這些物件之間呼叫與傳回的各種參數變數, 只要有一個地方對不 起來, 你的程式就會有問題... 於是使用者/客戶/老闆又有意見了; 上次那個某某幫我們加欄位, 半天就好了, 你為什麼 要弄那麼久 ? 呵呵...舉了一個很負面的OO應用例子, 給大家參考. -- ※ 發信站: 批踢踢實業坊(ptt.cc) ◆ From: 61.224.35.146

10/13 23:55, , 1F
推一下 這是我最近遇到的問題
10/13 23:55, 1F

10/13 23:56, , 2F
有什麼好的解決方法嗎?
10/13 23:56, 2F

10/14 22:05, , 3F
JAVA 的話,有 Java Persistence model 可供開發者建
10/14 22:05, 3F

10/14 22:07, , 4F
立 entity objects
10/14 22:07, 4F

11/21 04:16, , 5F
解決方法, 教育你的客戶 XD
11/21 04:16, 5F

08/30 15:11, , 6F
好的實例!!
08/30 15:11, 6F
文章代碼(AID): #18xZDb2W (OOAD)
討論串 (同標題文章)
文章代碼(AID): #18xZDb2W (OOAD)