OOAD 板


LINE

※ 引述《adrianshum (Alien)》之铭言: : ※ 引述《internaltide (internaltide)》之铭言: : : ~ : : EX. : : // 物件A : : class objectA{ : [43] : : public objectC; //合成的物件C : : public objectD; : : public function func1(){...} : : public function func2(){...} : : } : : // 继承物件A的物件B : : class objectB extend objectA{ : [43] : : } : : 可能同样的物件内容B跟C,但实际上当要取得物件A的资料时 : : 物件B可以很直觉的直接使用物件A的属性或间接使用方法来取得资料。 : : 但物件C就很麻烦了,变成我可能必须在A Class的建构式中时就要把资料 : : 想办法塞到C物件,搞到後来变成当D物件也需要相同资料时,我又得重复 : : 塞相同的资料到物件D。 晕!! : : 後来,我都是直接在物件A设了一个名为shareResources的阵列并宣告为Static, : : 再把所有共用资源都往那个阵列塞。 : : 然後,无论合成物件或继承物件都可以直接取用物件A的资料了。 : : 不晓得做法好不好,有没有大师提供更聪明的方法?? : 首先,当static 牵连到继承之类的话题,99% 都不会是正确的做法。 : 单想想,当你有两个 A instance, 你所谓 shared resource 放的是 : 哪个 A 的东西。 static牵连到继承有99%是错的做法? 不太懂... 属性被宣告为static时,不是就所有的A的实例所共用的了吗? : 然後看来你的认知有一个大问题。当谈及 继承 vs 合成,说的完全 : 不是你的在说的情况。在说以合成取代继承是类似长这样的东西: : class A {...} : class B extends A {.....} // 继承 : class C { // 合成 : private A a; : .... : } 可能是因为强调合成物件要取资料的问题,所以例子focus的点有点偏掉了。 不过我的观念: 当一个物件跟另一个物件具有Has-a的关系时就是一种合成关系, 某物件需要寄信功能时,不继承mailClass而是设定它有一个属性mailer, 然後让mailer是mailClass的实例 =>这就叫合成取代继承 这样应该没错了吧 ^^ : 当然这种情况之下, A 通常会有某种interface, 而 C : 也会提供这种 interface 并利用内部的 A instance 来 : 达成。 : 可是你在说的是 : class A { : private C c; : } : 这完全是不相干的话题。 : 至於你的情况下 C 怎样用到 A 的东西,这涉及你设计的问题, : 很难一概而论。当然最常做的是 C 也存着 A 的 reference 然後 : C 经此 ref access 包含着自己的那个 A。但更常见的做法是做 : 好设计,让 C 能不需要知道自己是被 A 所包含而单纯做好自己的 : 工作就够。 : Alien 嗯!! 让 C 能不需要知道自己是被 A 所包含而单纯做好自己的工作 物件导向设计是一条很遥远的路啊!! 谢谢 Alien罗!! --



※ 发信站: 批踢踢实业坊(ptt.cc)
◆ From: 114.36.190.22







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