CSSE 板


LINE

※ 引述《mgtsai (战车引擎保修官)》之铭言: : 标题: Re: [问题] 反design pattern的见解 : 时间: Sat Feb 10 06:23:20 2007 : 我想讨论这个问题,不过,我不太想在这里把讨论的层级拉太高 : 所以,就拿一个我自己过去所接过的案件当作实际案例来当作一个小小 case study : -- : 推 tinlans:我有点好奇,你是不是让 visitor 做太多事情了,并不一定 02/10 16:14 : → tinlans:所有的事情都要给 Accept() 转呼叫的东西通通做完吧, 02/10 16:15 : → tinlans:反正会选用 visitor 的时候,已经决定破坏被 visit 对象 02/10 16:15 : → tinlans:的封装性了,你可以把相关的资讯记录在这两者之外的地方。 02/10 16:16 : → tinlans:包括需要这些资讯才能完成的动作,也一并抽出 visitor。 02/10 16:17 我自己对 Visitor 的定位,是以比较望文生义的方式来看待 既然是  举个例子,就以 binary tree traversal 就至少有 pre-order, post-order, in-order 三种 而在进行每项任务时,会使用哪种 traversal 则是依状况而定 如果把整件事加以区分,我会指定以下机制: * Iterator 负责 tree traversal 方式 * 实际的任务执行,则於 Visitor 的 implementation class 中实作 (Visitor 本身则为 generic interface) 或者,在 Visitor 中弄个 delegation 把该执行的任务 delegate 到另一个 class hierarchy 里处理 * Visitor 则纯化为:它负责逛节点,藉由 accept() 对手中的任务进行 "分派" 至於逛节点的方式则由 Iterator 定义 至於执行什麽任务则由 implementation/delegation class 中处理 * 至於封装性的问题,则定义统一的使用介面,弄一个 Facade 供其它模组使用 就如同大家所述,使用 Visitor 时会碰到不少麻烦 甚至要完全依 GoF 的定义结构会碰上钉子 换句话说,虽然我们可以依照 pattern 的大方向进行 但面对实际的应用时,还是得牵就现实状况,作某种程度的调整 : 推 YuYuHo:vistor visit house,我觉得vistor最大的缺点 02/10 16:18 : → YuYuHo:是带给house太大的负担 02/10 16:21 : → YuYuHo:打错字了,是visitor,刚打完麻将回来,win~~ya~~ 02/10 22:52 : → YuYuHo:假如说house的内部节点其实是不稳定的型态,结果会造成 02/10 22:54 : → YuYuHo:visitor的介面也变得很不稳定,很容易就搞得一团乱 02/10 22:55 : → YuYuHo:通常采用visitor时,house本身的结构可能就很复杂了, 02/10 22:57 : → YuYuHo:这时候还要管理节点的分派策略,还要维持节点稳定, 02/10 23:01 : → YuYuHo:这表示house做好後就不能随便更动,很容易牵一发动全身. 02/10 23:02 这个问题,我会在所对应的 Iterator 中加以处理相关的机制 而 Visitor 与其相关的界面,我会尽量固定住而不去动它 --



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







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灯, 水草

请输入看板名称,例如:Gossiping站内搜寻

TOP