??xml version="1.0" encoding="utf-8" standalone="yes"?>久久久久亚洲av无码专区导航,在线观看亚洲精品福利片,亚洲欧美日韩综合俺去了http://www.tkk7.com/kangdy/category/47812.html我就像AK47里打出去的子式V目标TMD永远在前斏V我只能TMD拼命向前?/description>zh-cnThu, 03 Nov 2011 03:32:36 GMTThu, 03 Nov 2011 03:32:36 GMT60(转脓)java回调函数http://www.tkk7.com/kangdy/archive/2010/12/10/340238.htmlAK47AK47Fri, 10 Dec 2010 03:22:00 GMThttp://www.tkk7.com/kangdy/archive/2010/12/10/340238.htmlhttp://www.tkk7.com/kangdy/comments/340238.htmlhttp://www.tkk7.com/kangdy/archive/2010/12/10/340238.html#Feedback0http://www.tkk7.com/kangdy/comments/commentRss/340238.htmlhttp://www.tkk7.com/kangdy/services/trackbacks/340238.htmlhttp://ayzw001.blog.163.com/blog/static/1134114222009420112538726/ 引用Q?/legend> 所谓回调,是客户E序C调用服务E序S中的某个ҎaQ然后S又在某个时候反q来调用C中的某个ҎbQ对于C来说Q这个b便叫做回调函数?/p> 一般说来,C不会自己调用bQC提供b的目的就是让S来调用它Q而且是C不得不提供。由于Sq不知道C提供的b叫甚名谁Q所以S会约定b的接口规范(函数原型Q,然后由C提前通过S的一个函数r告诉S自己要使用b函数Q这个过E称为回调函数的注册QrUCؓ注册函数?/p> 下面举个通俗的例子: 某天Q我打电话向你请教问题,当然是个NQ?)Q你一时想不出解决ҎQ我又不能拿着电话在那里傻{,于是我们U定Q等你想出办法后打手机通知我,q样Q我挂掉电话办其它事情M。过了XX分钟Q我的手机响了,你兴高采烈的说问题已l搞定,应该如此q般处理。故事到此结束?/p> q个例子说明?#8220;异步+回调”的编E模式。其中,你后来打手机告诉我结果便是一?#8220;回调”q程Q我的手机号码必d以前告诉你,q便是注册回调函敎ͼ我的手机L应该有效q且手机能够接收C的呼叫,q是回调函数必须W合接口规范?/p> 如果你还不太清楚看看q段描述合和代码Q?/p> 声明一个接口,另外一个类有方法里面有个参C是这个接口类型的Q而后在另外类中实现这个接?java中多用的是匿名内部类)Q而且以这个匿名的cȝ成的对象为参CC面提到类中,而后实现回调.......q种用法可以参考java里面常用到的数据库操作所用到的几个接?.... //声明一个接?br /> public interface ICallBack { void postExec(); } //另外一个类有方法里面有个参C是这个接口类型的 public class FooBar { private ICallBack callBack; public void setCallBack(ICallBack callBack) { this.callBack = callBack; } public void doSth() { callBack.postExec(); } } --------------------------------------- 回调的实?br /> public class Test { public static void main(String[] args) { FooBar foo = new FooBar(); foo.setCallBack(new ICallBack() { public void postExec() { System.out.println("method executed."); } }); foo.doSth();//调用函数 } } AK47 2010-12-10 11:22 发表评论]]>(转脓) 真正理解面向接口~程http://www.tkk7.com/kangdy/archive/2010/11/05/337317.htmlAK47AK47Fri, 05 Nov 2010 06:09:00 GMThttp://www.tkk7.com/kangdy/archive/2010/11/05/337317.htmlhttp://www.tkk7.com/kangdy/comments/337317.htmlhttp://www.tkk7.com/kangdy/archive/2010/11/05/337317.html#Feedback0http://www.tkk7.com/kangdy/comments/commentRss/337317.htmlhttp://www.tkk7.com/kangdy/services/trackbacks/337317.html 问题是在实际的项目开发中我们是怎么体现的呢Q?N是每一个实现都提供一个接口就了事了?反过来说Q你有时候有没有觉得接口是多余的事? 又或者,你仅仅是觉得现在cMspringq样的框架已习惯用接口这U方式而心存当然? 设计模式解析里提C面向对象设计考虑的几个视角,一个是概念层,一个是规约层,一个是实现层。我如果没有猜错的话Q实际上我们大多Ch的眼睛一直是盯着实现层的Q而这正是面向对象设计所极力避免的,即你不要在一开始就xq些l节Q你要关注的是规U(接口Q? 对于实际目开发来_如果我们把实现的q程分ؓ多个阶段的话我们不妨q么划分Q第一阶段Q根据client端的需要去设计我们的规U?interface),在这个阶DQ何实现都没有Q所有的d是定义接口所需要的职责Q以及所需要的一些po,vo;W二阶段Q实现前面定义的规约?span style="color: red;">而以前我是怎么做的呢? 我是交叉作的Q即假模假样的定义一个接口(其实我心里在惌个东西有屁用Q?然后定义了一个方法,然后q卛_实现q个ҎQ再然后我又定义一个方法,l箋d玎ͼ我现在终于想通了Q这样好累,效率很低Q最重要的是Q这不属于真正的设计?br /> 现在我是怎么做的呢?比如一个list.jsp里需要查询,列表Q然后看明细信息Q然后增加信息,我会W一步在接口里定义完(q个q程会有整体设计的意?,毫不兛_底层实现(数据库、事?Q我的目标就?我想要这个功能,我想要那个功?Q至于那个功能怎么实现在第一阶段我认为那不是我的事情(管q个事情最l还是由我来? .大家看这个过E和前面的过E有什么本质的不同呢? 是分层的概忉|加明显,你的工作更有层次Q每ơ都有先设计再实现的步骤Q而前面那个过E很Ҏp你不知不觉地陷入U实现的陷阱中?br /> 一Ҏ惻IƢ迎大家拍砖?br /> 原帖地址Q?http://www.tkk7.com/alex/archive/2007/03/12/103185.html AK47 2010-11-05 14:09 发表评论]]>从追MM谈Java?3U设计模式(转)http://www.tkk7.com/kangdy/archive/2010/01/04/308188.htmlAK47AK47Mon, 04 Jan 2010 08:48:00 GMThttp://www.tkk7.com/kangdy/archive/2010/01/04/308188.htmlhttp://www.tkk7.com/kangdy/comments/308188.htmlhttp://www.tkk7.com/kangdy/archive/2010/01/04/308188.html#Feedback0http://www.tkk7.com/kangdy/comments/commentRss/308188.htmlhttp://www.tkk7.com/kangdy/services/trackbacks/308188.htmlq样学习设计模式肯定便于理解Q?br /> http://hi.baidu.com/xghzlg/blog/item/3288de589071d7202934f06f.html
所谓回调,是客户E序C调用服务E序S中的某个ҎaQ然后S又在某个时候反q来调用C中的某个ҎbQ对于C来说Q这个b便叫做回调函数?/p>
一般说来,C不会自己调用bQC提供b的目的就是让S来调用它Q而且是C不得不提供。由于Sq不知道C提供的b叫甚名谁Q所以S会约定b的接口规范(函数原型Q,然后由C提前通过S的一个函数r告诉S自己要使用b函数Q这个过E称为回调函数的注册QrUCؓ注册函数?/p>
下面举个通俗的例子:
某天Q我打电话向你请教问题,当然是个NQ?)Q你一时想不出解决ҎQ我又不能拿着电话在那里傻{,于是我们U定Q等你想出办法后打手机通知我,q样Q我挂掉电话办其它事情M。过了XX分钟Q我的手机响了,你兴高采烈的说问题已l搞定,应该如此q般处理。故事到此结束?/p>
q个例子说明?#8220;异步+回调”的编E模式。其中,你后来打手机告诉我结果便是一?#8220;回调”q程Q我的手机号码必d以前告诉你,q便是注册回调函敎ͼ我的手机L应该有效q且手机能够接收C的呼叫,q是回调函数必须W合接口规范?/p>
如果你还不太清楚看看q段描述合和代码Q?/p>
声明一个接口,另外一个类有方法里面有个参C是这个接口类型的Q而后在另外类中实现这个接?java中多用的是匿名内部类)Q而且以这个匿名的cȝ成的对象为参CC面提到类中,而后实现回调.......q种用法可以参考java里面常用到的数据库操作所用到的几个接?....
//声明一个接?br /> public interface ICallBack { void postExec(); }
//另外一个类有方法里面有个参C是这个接口类型的 public class FooBar { private ICallBack callBack; public void setCallBack(ICallBack callBack) { this.callBack = callBack; } public void doSth() { callBack.postExec(); } } --------------------------------------- 回调的实?br /> public class Test { public static void main(String[] args) { FooBar foo = new FooBar(); foo.setCallBack(new ICallBack() { public void postExec() { System.out.println("method executed."); } }); foo.doSth();//调用函数 } }
从追MM谈Java?3U设计模?br /> 设计模式做ؓE序员的“内功心法”Q越来越受到.net C的重视,q种变化是很可喜的,JavaC走在了我们的前面Q但q种状况也许有一天会发生改变?/p>
从追MM谈Java?3U设计模?/p>
1、FACTORY—追MM不了请吃饭了,麦当劳的鸡翅和肯德基的鸡都是MM爱吃的东西,虽然口味有所不同Q但不管你带MM去麦当劳或肯 德基Q只向服务员说“来四个鸡?#8221;p了。麦当劳和肯德基是生鸡翅的Factory.
工厂模式Q客L和工厂类分开。消费者Q何时候需要某U品,只需向工厂请求即可。消费者无M改就可以接纳C品。缺?是当产品修改Ӟ工厂cM要做相应的修攏V如Q如何创建及如何向客L提供?/p>
E序代码
以下是引用片D:
以下是引用片D: public class Factory{ public String Boy = "boy" ; public String Girl = "girl" ; public People getPeople (String people){ if (people.equals("boy")){ return new Boy(); }else if(people.equals("girl")){ return new Girl(); } } }
2、BUILDER—MM最爱听的就?#8220;我爱?#8221;q句话了Q见C同地方的MM,要能够用她们的方a跟她说这句话哦,我有一个多U语a译机,上面每种语言都有一个按键,见到MM我只要按对应的键Q它p够用相应的语a说出“我爱?#8221;q句话了Q国外的MM也可以轻松搞掂,q就是我?#8220;我爱?#8221;builder?q一定比军在伊拉克用的译机好?
建造模式:品的内部表象和品的生成q程分割开来,从而一个徏造过E生成具有不同的内部表象的品对象。徏造模式?产品内部表象可以独立的变化,客户不必知道产品内部l成的细节。徏造模式可以强制实行一U分步骤q行的徏造过E?/p>
3、FACTORY METHOD—请MM去麦当劳吃汉堡,不同的MM有不同的口味Q要每个都记住是一件烦人的事情Q我一般采用Factory Method?式,带着MM到服务员那儿Q说“要一个汉?#8221;Q具体要什么样的汉堡呢Q让MM直接跟服务员说就行了?/p>
工厂Ҏ模式Q核心工厂类不再负责所有品的创徏Q而是具体创建的工作交给子类dQ成Z个抽象工厂角Ԍ仅负责给?具体工厂cdd现的接口Q而不接触哪一个品类应当被实例化q种l节?/p>
4、PROTOTYPE—跟MM用QQ聊天Q一定要说些深情的话语了Q我搜集了好多肉ȝ情话Q需要时只要copy出来攑ֈQQ里面p了,q就?我的情话prototype了?100块钱一份,你要不要)
原始模型模式Q通过l出一个原型对象来指明所要创建的对象的类型,然后用复制这个原型对象的Ҏ创徏出更多同cd的对象。原始模型模式允许动态的增加或减品类Q品类不需要非得有M事先定的等U结构,原始模型模式适用于Q何的{l构。缺Ҏ每一个类都必配备一个克隆方法?/p>
5、SINGLETON—俺?个漂亮的老婆Q她们的老公都是我,我就是我们家里的老公SigletonQ她们只要说?#8220;老公”Q都是指的同一?人,那就是我(刚才做了个梦啦,哪有q么好的?
单例模式Q单例模式确保某一个类只有一个实例,而且自行实例化ƈ向整个系l提供这个实例单例模式。单例模式只应在有真正的 “单一实例”的需求时才可使用?/p>
以下是引用片D: public class SingLeton{ private static SingLeton instance = new SingLeton(); public static SingLeton getInstance(){ return instance; } }
6、ADAPTER—在朋友聚会上碰C一个美女SarahQ从香港来的Q可我不会说_语Q她不会说普通话Q只好求助于我的朋友kent了,?作ؓ我和Sarah之间的AdapterQ让我和Sarah可以怺交谈?也不知道他会不会耍我)
适配?变压?模式Q把一个类的接口变换成客户端所期待的另一U接口,从而原本因接口原因不匚w而无法一起工作的两个c?能够一起工作。适配cd以根据参数返q一个合适的实例l客L?/p>
7、BRIDGE—早上碰到MMQ要说早上好Q晚上碰到MMQ要说晚上好; 到MMI了件新服Q要说你的服好漂亮哦,到MM新做的发型, 要说你的头发好漂亮哦。不要问?#8220;早上到MM新做了个发型怎么?#8221;q种问题Q自qBRIDGEl合一下不p?/p>
桥梁模式Q将抽象化与实现化脱耦,使得二者可以独立的变化Q也是说将他们之间的强兌变成弱关联,也就是指在一个Y件系l的 抽象化和实现化之间用组?聚合关系而不是承关p,从而两者可以独立的变化?/p>
8、COMPOSITE—Mary今天q生日?#8220;我过生日Q你要送我一件礼物?#8221;“嗯,好吧Q去商店Q你自己挑?#8221;“qgT恤挺漂亮Q买Q这条裙子好看,乎ͼq个包也不错Q买?#8221;“喂,C三g了呀Q我只答应送一件礼物的哦?#8221;“什么呀QT恤加裙子加包包,正好配成一套呀Q小姐,ȝ你包h?#8221;“……”QMM都会用Composite模式了,你会了没?
合成模式Q合成模式将对象l织到树l构中,可以用来描述整体与部分的关系。合成模式就是一个处理对象的树结构的模式。合?模式把部分与整体的关pȝ树结构表C出来。合成模式得客L把一个个单独的成分对象和׃们复合而成的合成对象同{看待?/p>
9、DECORATOR—Maryq完轮到Sarlyq生日,q是不要叫她自己挑了Q不然这个月伙食费肯定玩完,拿出我去q在华山上照的照片Q在背面写上“最好的的礼物,是׃的Fita”Q再到街上礼品店C个像?卖礼品的MM也很漂亮?Q再N壁搞术设计的Mike设计了一个漂亮的盒子装v?#8230;…Q我们都是DecoratorQ最l都在修饰我q个人呀Q怎么P看懂了吗?
装饰模式Q装饰模式以对客L透明的方式扩展对象的功能Q是l承关系的一个替代方案,提供比承更多的灉|性。动态给一?对象增加功能Q这些功能可以再动态的撤消。增加由一些基本功能的排列l合而生的非常大量的功能?/p>
10、FA?ADE—我有一个专业的Nikon相机Q我喜Ƣ自己手动调光圈、快门,q样照出来的照片才专业,但MM可不懂这些,教了半天也不会。幸好相机有Fa?ade设计模式Q把相机调整到自动Q只要对准目标按快门p了,一切由相机自动调整Q这样MM也可以用q个相机l我拍张照片了?/p>
门面模式Q外部与一个子pȝ的通信必须通过一个统一的门面对象进行。门面模式提供一个高层次的接口,使得子系l更易于使用 。每一个子pȝ只有一个门面类Q而且此门面类只有一个实例,也就是说它是一个单例模式。但整个pȝ可以有多个门面类?/p>
11、FLYWEIGHT—每天跟MM发短信,手指都篏MQ最q买了个新手机,可以把一些常用的句子存在手机里,要用的时候,直接拿出来,在前面加上MM的名字就可以发送了Q再不用一个字一个字敲了。共享的句子是FlyweightQMM的名字就是提取出来的外部特征Q根据上下文情况使用?/p>
享元模式QFLYWEIGHT在拳L赛中指最轻量U。n元模式以׃n的方式高效的支持大量的细_度对象。n元模式能做到׃n的关键是区分内蕴状态和外蕴状态。内蕴状态存储在享元内部Q不会随环境的改变而有所不同。外蕴状态是随环境的改变而改变的。外蕴状态不能媄响内蕴状态,它们是相互独立的。将可以׃n的状态和不可以共享的状态从常规cM区分开来,不可以׃n的状态从c里剔除出去。客L不可以直接创׃n的对象,而应当用一个工厂对象负责创׃n的对象。n元模式大q度的降低内存中对象的数量?/p>
12、PROXY—跟MM在网上聊天,一开头L“hi,你好”,“你从哪儿来呀?”“你多大了?”“w高多少呀?”q些话,真烦人,写个E序 做ؓ我的Proxy吧,凡是接收到这些话都设|好了自动的回答Q接收到其他的话时再通知我回{,怎么P酷吧?/p>
代理模式Q代理模式给某一个对象提供一个代理对象,q由代理对象控制Ҏ对象的引用。代理就是一个h或一个机构代表另一个h或者一个机构采取行动。某些情况下Q客户不x者不能够直接引用一个对象,代理对象可以在客户和目标对象直接起到中介的作用。客L分L不出代理主题对象与真实主题对象。代理模式可以ƈ不知道真正的被代理对象,而仅仅持有一个被代理对象的接口,q时候代理对象不能够创徏被代理对象,被代理对象必Lpȝ的其他角色代为创建ƈ传入?/p>
以下是引用片D: public interface FactoryProxy{ public People createBoy(); public People creteGirl(); }
13、CHAIN OF RESPONSIBLEITY—晚上去上英语课Qؓ了好开溜坐C最后一排,哇,前面坐了好几个漂亮的MM哎,扑ּU条Q写?“Hi,可以做我的女朋友?如果不愿意请向前?#8221;Q纸条就一个接一个的传上MQ糟p,传到W一排的MM把纸条传l老师了,听说是个老处奛_Q快?
责Q链模式:在责任链模式中,很多对象由每一个对象对其下家的引用而接
h形成一条链。请求在q个链上传递,直到链上的某一个对象决定处理此h。客户ƈ不知道链上的哪一个对象最l处理这个请求,pȝ可以在不影响客户端的情况下动态的重新l织铑֒分配责Q。处理者有两个选择Q承担责L者把责Q推给下家。一个请求可以最l不被Q何接收端对象所接受?/p>
14、COMMAND—俺有一个MM安得特别严,没法见面Q只好借助于她弟弟在我们俩之间传送信息,她对我有什么指C,写一张纸条让她弟弟带l我。这不,她弟弟又传送过来一个COMMANDQؓ了感谢他Q我请他吃了杂酱面Q哪知道他说Q?#8220;我同时给我姐姐三个男朋友?COMMANDQ就C最气Q才h吃面?#8221;Q?/p>
命o模式Q命令模式把一个请求或者操作封装到一个对象中。命令模式把发出命o的责d执行命o的责d割开Q委z不同的对象。命令模式允许请求的一方和发送的一方独立开来,使得h的一方不必知道接收请求的一方的接口Q更不必知道h是怎么被接Ӟ以及操作是否执行Q何时被执行以及是怎么被执行的。系l支持命令的撤消?/p>
15、INTERPRETER—俺有一个《MM真经》,上面有各UMM的攻略,比如说去吃西的步骤、去看电qҎ{等Q跟MMU会Ӟ?要做一个InterpreterQ照着上面的脚本执行就可以了?/p>
解释器模式:l定一个语a后,解释器模式可以定义出其文法的一U表C,q同时提供一个解释器。客L可以使用q个解释器来解释q个语言中的句子。解释器模式描q怎样在有了一个简单的文法后,使用模式设计解释q些语句。在解释器模式里面提到的语言是指M解释器对象能够解释的Ml合。在解释器模式中需要定义一个代表文法的命ocȝ{l构Q也是一pd的组合规则。每一个命令对象都有一个解释方法,代表对命令对象的解释。命令对象的{l构中的对象的Q何排列组合都是一个语a?/p>
16、ITERATOR—我׃了MaryQ不一切的向她求婚?/p>
MaryQ?#8220;惌我跟你结婚,得答应我的条?#8221;
我:“什么条件我都答应,你说?#8221;
MaryQ?#8220;我看上了那个一克拉的钻?#8221;
我:“我买Q我乎ͼq有?”
MaryQ?#8220;我看上了湖边的那栋别?#8221;
MaryQ?#8220;我看上那辆法拉利跑R”
我脑袋嗡的一壎ͼ坐在椅子上,一咬牙Q?#8220;我买Q我乎ͼq有?”
……
q代子模式:q代子模式可以顺序访问一个聚集中的元素而不必暴露聚集的内部表象。多个对象聚在一起Ş成的MUC集,聚集对象是能够包容一l对象的容器对象。P代子模式P代逻辑装C个独立的子对象中Q从而与聚集本n隔开。P代子模式化了聚集的界面。每一个聚集对象都可以有一个或一个以上的q代子对象,每一个P代子的P代状态可以是彼此独立的。P代算法可以独立于聚集角色 变化?/p>
17、MEDIATOR—四个MM打麻,怺之间谁应该给谁多钱不清楚了,q怺当时我在旁边Q按照各自的{码数算钱,赚了q从我q?里拿Q赔了钱的也付给我,一切就OK啦,俺得C四个MM的电话?/p>
调停者模式:调停者模式包装了一pd对象怺作用的方式,使得q些对象不必怺明显作用。从而他们可以松散偶合。当某些对象之间的作用发生改变时Q不会立卛_响其他的一些对象之间的作用。保证这些作用可以彼此独立的变化。调停者模式将多对多的怺作用转化Z对多的相互作用。调停者模式将对象的行为和协作抽象化,把对象在尺度的行ؓ上与其他对象的相互作用分开处理?/p>
18、MEMENTO—同时跟几个MM聊天Ӟ一定要记清楚刚才跟MM说了些什么话Q不然MM发现了会不高兴的哦,q怺我有个备忘录Q刚才与 哪个MM说了什么话我都拯一份放到备忘录里面保存Q这样可以随时察看以前的记录啦?/p>
备忘录模式:备忘录对象是一个用来存储另外一个对象内部状态的快照的对象。备忘录模式的用意是在不破坏装的条件下Q将一 个对象的状态捉住,q外部化Q存储v来,从而可以在来合适的时候把q个对象q原到存储v来的状态?/p>
19、OBSERVER—想知道׃公司最新MM情报?加入公司的MM情报邮gl就行了Qtom负责搜集情报Q他发现的新情报不用一个一个通知 我们Q直接发布给邮gl,我们作ؓ订阅?观察?可以及时收到情报啦
观察者模式:观察者模式定义了一U一队多的依赖关p,让多个观察者对象同时监听某一个主题对象。这个主题对象在状态上发生 变化Ӟ会通知所有观察者对象,使他们能够自动更新自己?/p>
20、STATE—跟MM交往Ӟ一定要注意她的状态哦Q在不同的状态时她的行ؓ会有不同Q比如你U她今天晚上ȝ电媄Q对你没兴趣?MM׃?#8220;有事情啦”Q对你不讨厌但还没喜Ƣ上的MM׃?#8220;好啊Q不q可以带上我同事?”Q已l喜Ƣ上你的MM׃?#8220;几点?看完电媄再去泡吧怎么?”Q当然你看电pE中表现良好的话Q也可以把MM的状态从不讨厌不喜欢变成喜欢哦?/p>
状态模式:状态模式允怸个对象在其内部状态改变的时候改变行为。这个对象看上去象是改变了它的类一栗状态模式把所研究的对象的行ؓ包装在不同的状态对象里Q每一个状态对象都属于一个抽象状态类的一个子cR状态模式的意图是让一个对象在其内部状态改变的时候,其行Z随之改变。状态模式需要对每一个系l可能取得的状态创立一个状态类的子cR当pȝ的状态变化时Q系l便改变所选的?cR?/p>
21、STRATEGY—跟不同cd的MMU会Q要用不同的{略Q有的请电媄比较好,有的则去吃小吃效果不错,有的LvҎ漫最合适,单目 的都是ؓ了得到MM的芳心,我的qMM锦囊中有好多Strategy哦?/p>
{略模式Q策略模式针对一l算法,每一个算法封装到h共同接口的独立的cMQ从而得它们可以相互替换。策略模式得算法可以在不媄响到客户端的情况下发生变化。策略模式把行ؓ和环境分开。环境类负责l持和查询行为类Q各U算法在具体的策略类中提供。由于算法和环境独立开来,法的增减,修改都不会媄响到环境和客L?/p>
22、TEMPLATE METHOD——看q《如何说服女生上床》这部经典文章吗?女生从认识到上床的不变的步骤分ؓ巧遇、打破僵局、展开q求、接吅R前戏、动手、爱抚、进d大步?Template method)Q但每个步骤针对不同的情况,都有不一L做法Q这p看你随机应变?具体实现);
模板Ҏ模式Q模板方法模式准备一个抽象类Q将部分逻辑以具体方法以及具体构造子的Ş式实玎ͼ然后声明一些抽象方法来q子类实现剩余的逻辑。不同的子类可以以不同的方式实现q些抽象ҎQ从而对剩余的逻辑有不同的实现。先制定一个顶U逻辑框架Q而将逻辑的细节留l具体的子类d现?/p>
23、VISITOR—情CQ要l每个MM送一束鲜花和一张卡片,可是每个MM送的花都要针对她个h的特点,每张卡片也要Ҏ个h的特Ҏ挑,我一个h哪搞得清楚,q是找花店老板和礼品店老板做一下VisitorQ让花店老板ҎMM的特炚w一束花Q让C品店老板也根据每个h特点选一张卡Q这样就L多了;
讉K者模式:讉K者模式的目的是封装一些施加于某种数据l构元素之上的操作。一旦这些操作需要修改的话,接受q个操作的数据结构可以保持不变。访问者模式适用于数据结构相Ҏ定的pȝQ它把数据结构和作用于结构上的操作之间的耦合解脱开Q得操作集合可以相对自q演化。访问者模式得增加新的操作变的很ҎQ就是增加一个新的访问者类。访问者模式将有关的行为集中到一个访问者对象中Q而不是分散到一个个的节点类中。当使用讉K者模式时Q要尽可能多的对象览逻辑攑֜讉K者类中,而不是放到它的子cM。访问者模式可以跨q几个类的等U结构访问属于不同的{l构的成员类?/p>
package com.kangdy.test;
public interface UserManager { public void addUser(String userName); }
public class UserManagerImpl implements UserManager {
public void addUser(String userName) { System.out.println("用户 : "+userName+" d成功"); }
}
import java.lang.reflect.InvocationHandler; import java.lang.reflect.Method; import java.lang.reflect.Proxy;
public class JDKStaticProxy implements InvocationHandler{ //目标对象索引 private Object targetObject; /* * 通过构造方法引入目标对?br /> */ public JDKStaticProxy(Object targetObject){ this.targetObject = targetObject; } /* * 创徏代理对象 */ public Object createProxyObject(){ Object proxyObject = Proxy.newProxyInstance( this.targetObject.getClass().getClassLoader(), this.targetObject.getClass().getInterfaces(), this); return proxyObject; } /* * proxyObject:代理对象 * method: 被拦截到的目标对象的method * args: 被拦截到的目标对象的method的参?br /> * (non-Javadoc) * @see java.lang.reflect.InvocationHandler#invoke(java.lang.Object, java.lang.reflect.Method, java.lang.Object[]) */ public Object invoke(Object proxyObject, Method method, Object[] args) throws Throwable { //d业务逻辑 busniessLogic(); //代理q行目标对象的method Object result = method.invoke(this.targetObject, args); return result; } /* * d业务逻辑Q这里只是简单打C句话?br /> */ private void busniessLogic(){ System.out.println("q是代理Ҏ"); } }
代理cLd很多注释。应该很清楚了。这里我单说一下流E:当代理对象被调用的时候先会执行invokeҎQ在此方法里面我们可d 自己的业务逻辑代码Q然后才会执行目标对象的真实ҎQmethod.invoke(this.targetObject, args);目标对象Ҏ可能会有q回|在这 里当存在q回值的时候我们返回一个Object.
下面代码是客L调用和调用结果:
import org.junit.Test;
public class TestJDKStaticProxy { @Test public void testJDKStaticProxy(){ JDKStaticProxy proxy = new JDKStaticProxy(new UserManagerImpl()); UserManager userManager = (UserManager) proxy.createProxyObject(); userManager.addUser("张三"); } }