本文属贫僧不吃肉原创,欢迎转载,转载请注明来自 http://never-say-never.iteye.com/blog/851923
在开始之前,先熟悉一下OO设计的一些原则。
OO设计原则之一:封装变化
找出应用中可能需要变化之处,把他们独立出来,不要和那些不需要变化的代码混在一起。
OO设计原则之二:多用组合,少用继承
组合(composition)和继承不同的地方在于,对象的行为不是通过继承来的,而是和适当的行为对象(算法族)“组合”来的。
OO设计原则之三:面向接口编程
针对接口编程而不是针对实现编程。
所以,得到了如下的定义。
策略模式:(把变化之处抽象出来)定义算法族,分别封装,让他们之间可以互相替换,此模式让算法的变化独立于使用算法的客户。 --《Head first设计模式》
先来一个抽象女子类,女子有一个动作show(),每位女子的动作都会不同,比如貂蝉喜欢看月亮,马诺喜欢抽鞭子,浮云妹子喜欢看世博,小泉彩喜欢拍爱情教育片等等。
正是因为每朵女子的“动作”不同,如果使用继承Lady类的方式来构造子类的话,那就得给每个子类重写父类的show()。
为了更好的实现代码复用,因此我们请出策略模式
public abstract class Lady{
Behavior behavior ;
public void setBehavior(b){
this.behavior=b;
}
public void show(){
behavior.show();
}
public void smile(){
System.out.println(“刷牙,姐一直用舒肤佳!”)
}
}
其实,把凤姐定义成一个类,似乎不太妥当,应该是个对象。但是把它想成“像凤姐的那一类人”就合理多了~~哈哈,开个玩笑,我是懒得返回去改了,将就看一下吧~
public class FengJie extends Lady{
//定义凤姐类
public FengJie(){
behavior=new Merry();
}
public class FuRong extends Lady{
//定义芙蓉姐姐类
public FuRong(){
behavior=new Dance();
}
}
根据OO设计原则,我们抽象出了“变化”的部分 — 女子的动作 ,因为每个女子的动作都不一样
public interface Behavior{
public void show();
}
//定义结婚类
public class Merry implements Behavior{
public void show(){
System.out.println(“人家只嫁给氢化烟酒僧~”);
}
}
//定义芙蓉姐姐的跳舞类~~
public class Dance implements Behavior{
public void show(){
System.out.println(“姐不是巴黎欧莱雅,你不值得拥有”);
}
}
好了,写个测试类,来测试一下
public class Test{
public static void main(String[] args) {
Lady fj = new FengJie(); //凤姐
lady fr = new FuRong(); //芙蓉姐姐
fj.show(); //小凤,秀一下
fj.smile(); //小凤,笑一个
fr.show(); //芙蓉姐姐,秀一下
fr.smile(); //芙蓉姐姐,笑一个
}
}
所以,通过抽象“变化”的部分,分离开固定的和活动的,然后,面向接口。
前面说的好像有点水,如果看懂了,你很强。如果没看懂,没关系,下面我们再换个角度思考一下策略模式。
简单,就好比魔兽,英雄是父类,子类有剑圣、圣骑,每个子英雄拥有的技能是不同的,但是总的技能就那么几十种,只是每个英雄取的技能组合不同而已。
如果把几十种技能全写进父类里,那子英雄继承的时候就把需要的和不需要的技能都全部继承过去了。
如果把父类拥有技能写成虚函数,那又要给每一个英雄实现拥有技能函数。
...
而用策略模式怎么解决这个问题的呢:
1.找出变化的部分:技能,再把它声明成一个总的抽象技能接口
2.给每个子技能接口一个实现,如:医疗波,战争践踏等
3.把英雄和其具备的技能组合(composition)到一起,如牛头和战争践踏、冲击波等组合。
//OO思想:多用组合,少用继承
这样,在保证每个英雄都具有不同技能的同时,也最大地实现了代码的重用。因为,每个技能只用实现一次就可以了。
分享一些小弟在网上或书上看到的短句,仔细品味后发现,觉得很有用,努力ing~。
1.良好的OO设计必须具备可复用、可扩充、可维护三个特性
2.模式不是代码,而是针对设计问题的通用解决方案。
3.模式不是被发明,而是被发现的。
4.我们常把系统中会变化的部分抽出来封装。
5.模式让开发人员之间有共享的语言,能够最大化沟通的价值。
附上策略模式的一个很好的实现例子给大家交流学习~~
分享到:
相关推荐
《HeadFirst设计模式学习笔记1--策略模式Demo》 在软件工程中,设计模式是一种解决常见问题的标准方案,它提供了一种在特定情况下组织代码的模板。策略模式是设计模式中的一种行为模式,它允许在运行时选择算法或...
《Head First设计模式》是一本深受开发者喜爱的设计模式学习书籍,它以易懂且生动的方式介绍了23种经典设计模式。这些模式是软件工程中经过实践验证的最佳实践,旨在提高代码的可重用性、可读性和可维护性。下面,...
在“HeadFirst 设计模式学习笔记3--装饰模式 Demo”中,作者通过实例讲解了装饰模式的基本概念、结构和应用场景。这篇文章可能是从CSDN博客平台上的一个链接访问的,遗憾的是,由于我们当前无法直接访问该链接,所以...
笔记_HeadFirst设计模式
《HeadFirst设计模式学习笔记》是一份详尽的资料,旨在帮助读者深入理解并掌握设计模式这一编程领域的核心概念。设计模式是软件工程中的一种最佳实践,它在解决常见问题时提供了一种标准的解决方案,使得代码更易于...
总的来说,HeadFirst设计模式的学习笔记2关于观察者模式的演示,旨在帮助开发者理解如何使用观察者模式来构建可扩展的系统。通过实际的代码示例,我们可以更深入地掌握这一模式,并将其应用到日常开发中,提升代码的...
通过上述对Head First设计模式学习笔记的解析,我们可以看到每种模式都在特定场景下发挥了重要作用,帮助开发者更好地组织代码,提高程序的可扩展性和可维护性。在实际项目中灵活运用这些设计模式,可以有效提升软件...
HeadFirst设计模式 读书 笔记
《Head First 设计模式》是软件开发领域内一本广受欢迎的书籍,由Eric Freeman、Elisabeth Robson、Bert Bates和Kathy Sierra四位作者共同撰写。这本书以其独特的视觉风格和易于理解的教学方法,深入浅出地介绍了...
### Head.First 设计模式学习笔记知识点总结 #### 一、设计模式概述 设计模式是一种用于解决软件设计中常见问题的标准化方法。通过采用设计模式,开发者可以提高代码的复用性、灵活性和可维护性。《Head First 设计...
读书笔记:设计模式学习笔记和代码。《图解设计模式》《Head First 设计模式》
《HeadFirst设计模式笔记》是深入理解软件设计思想的一份宝贵资料,主要涵盖了设计模式的基础理论和实际应用。设计模式是软件开发中的经验总结,它为解决常见的编程问题提供了标准的解决方案,使得代码更具可读性、...
在《Head First 设计模式学习笔记(十四)模式的组合使用》中,作者探讨了如何在实际编程中灵活地组合多种设计模式以解决复杂问题。这篇文章可能是基于《Head First 设计模式》这本书的一个章节,该书是设计模式领域...
根据提供的信息,“Head First设计模式”是一本广受好评的设计模式书籍。虽然具体的章节内容没有给出,但从描述中得知本书的第22页至39页涵盖了重要的设计模式概念,因此我们将围绕这些页面可能涉及的设计模式进行...
本项目为《Head First 设计模式》的Java语言学习笔记与实战练习源码集合,包含104个文件,主要包括88个Java源文件、12个Markdown文档、3个XML配置文件及少量其他辅助文件。内容涵盖设计模式的学习笔记以及相应的代码...
《Head First 策略者模式》学习笔记 策略者模式是一种行为设计模式,它使你能在运行时改变对象的行为。在软件开发中,我们常常遇到需要根据不同的情况执行不同算法的问题。策略者模式就是为了解决这类问题而生,它...
著名的《Head First Design Pattern》学习笔记,摘要这本书中的设计思路。由于书本过长,整理出笔记帮助回想起设计模式。文件是docx格式,只能由OFFICE Word 2007之后的版本打开,内附Visio类图文件。本文由个人整理...
以上只是《Head First Servlets & JSP》一书中的部分核心知识点,实际内容还包括过滤器、监听器、MVC设计模式、JSTL等更广泛的主题,旨在帮助读者全面理解和掌握Servlet和JSP技术。通过深入学习,开发者能够构建高效...