面试官都爱问的java模式之装饰模式!!!
简言:
Java中的23种设计模式:
Factory(工厂模式),Singleton(单例模式),Adapter(适配器模式),FactoryMethod(工厂方法模式),Prototype(原始模型模式),Facade(门面模式),Bridge(桥梁模式),Composite(合成模式),Builder(建造模式),Decorator(装饰模式),Flyweight(享元模式),Proxy(代理模式),Command(命令模式),Interpreter(解释器模式),Visitor(访问者模式),Iterator(迭代子模式),Mediator(调停者模式),Memento(备忘录模式),Observer(观察者模式),State(状态模式),Strategy(策略模式),TemplateMethod(模板方法模式),ChainOfResponsibleity(责任链模式)
我们在开发中都会用到哪些设计模式呢?
每个模式都描述了一个在我们的环境中不断出现的问题,然后描述了该问题的解决方案的核心。通过这种方式,你可以无数次地使用那些已有的解决方案,无需在重复相同的工作。主要用到了MVC的设计模式。用来开发JSP/Servlet或者J2EE的相关应用。简单工厂模式等。
今天我们主要讲的是装饰模式
定义:动态地给一个对象添加一些额外的职责,就增加功能来说,装饰模式比生成子类更加灵活;
装饰模式的结构图(网上查找的,流程关系比较详细)
1) Component定义一个对象接口,可以给对象动态的添加职责
2)ConcreteComponent 定义了一个具体的对象,可以给对象添加一些职责
3) Decorator :装饰抽象类。继承Component类并扩展功能,
4) ConcreteDecorator :具体的装饰对象
我们通过一个案例与代码的配合讲解装饰模式
案例讲解:小草要去相亲,如何搭配自己的穿搭,让她相亲的女神相中自己:
1)定义抽象类(Person)为了展示给女神
public abstract class Person {public abstract void show();
}
2)定义Compinent类继承Person(介绍小草的风格)
public class Component extends Person {@Overridepublic void show() {System.out.println("小草的风格");}
}
3) 定义一个Finery类 继承自ComPinent类(如何的装扮自己让女神爱上自己)
public class Finery extends Component {private Component component;/*** 装扮自己设置 Component* */public void DecoratorMy(Component components){this.component = components;}// 重写show() 实际执行的是Person的show();@Overridepublic void show() {if(component != null){component.show();}}
}
4)各种的穿衣风格
class DustCoat extends Finery{@Overridepublic void show() {super.show();System.out.println("风衣");}
}public class fleece extends Finery{@Overridepublic void show() {super.show();System.out.println("卫衣");}
}public class shirt extends Finery{@Overridepublic void show() {super.show();System.out.println("衬衫");}
}class Tshirts extends Finery{@Overridepublic void show() {super.show();System.out.println("T恤");}
}public class Western extends Finery{@Overridepublic void show() {super.show();System.out.println("西服");}
}
5)展示给女神(客户端实现)
public static void main(String[] args) {System.out.println("\n第一种装扮");Component person = new Component();HipHop hipHop = new HipHop();fleece fleece = new fleece();hipHop.DecoratorMy(person);fleece.DecoratorMy(hipHop);fleece.show();System.out.println("\n第二种装扮");Western western = new Western();shirt shirt = new shirt();DustCoat dustCoat = new DustCoat();western.DecoratorMy(person);shirt.DecoratorMy(western);dustCoat.DecoratorMy(shirt);dustCoat.show();}
6)相亲成功 显示结果
案例中:装饰模式是利用
对对象进行包装的,这样每个装饰对象的实现就和如何使用这个对象分离了,每个装饰对象关系的是自己的功能。不需要关系如何被添加到对象连当中;
如果只有一个ConcreteCompinent类没有抽象的Compinent类,nameDecorator类可以使ConcreteComponent的一个子类,同样道如果只有一个ConcreteDecorator类,那么久没有必要建立一个单独的Decorator类,而可以把Decorartor和ConceteDecorator的责任合并成一个类
装饰模式的总结:
装饰模式是为了已有功能动态的添加更多功能的一种方式,当系统需要新功能的时候,向就得类中添加新的代码,这些新的代码通常装饰了原有类的核心职责,装饰模式是提供了一个非常好的解决方案,把每个要装饰的功能放在单独的类中,并让这个类包装她所要装饰的对象,在需要特殊行为时,客户端代码就可以运行时根据需要选择的使用装饰功能包装对象了
装饰模式的优点:
优点:把类中的装饰功能从类中移除,这样简化原有的类,有限地把累的核心职责和装饰功能分离。并去除相关的重复装饰逻辑,
面试官都爱问的java模式之装饰模式!!!相关推荐
- 面试官都爱问的java模式之建造者模式!!!
开心一刻: 同事妻管严,零花钱少的可怜,今天一起打牌他输了400块没钱了.想想也可怜,就请他吃饭,吃饭时他说兄弟借十块钱吧,买张请柬回去好报帐,我当时就呆了,又TM学会一招... 简言: 建造者模式定 ...
- java 实体类包含list 怎么取值_舅舅是面试官,偷偷告诉你们面试官最爱问的Java面试题...
2015 年,因为工作岗位的变动,舅舅开始负责给集团招聘一些技术人员,出于对公司的负责,也为了更好的胜任技术经理的职位,在面试的这件事上,舅舅做了大量的"功课",首先研究了几乎所有 ...
- 面试 HTTP ,99% 的面试官都爱问这些问题!
点击上方"方志朋",选择"设为星标" 回复"666"获取新整理的面试文章 本文来源:Java建设者 HTTP 和 HTTPS 的区别 HTT ...
- 为什么面试官都爱问源码?这几个公众号告诉你!
技术之路就是漫长的打怪升级,不断学习前人的踩坑经验才能提升自己,切忌闭门造车.所谓独乐乐不如众乐乐,强烈推荐以下公众号,让你的生活多点意思????,希望小伙伴们能在 coding 的路上走的更远. 「 ...
- 面试 HTTP ,99% 的面试官都爱问这些问题
HTTP 和 HTTPS 的区别 HTTP 是一种 超文本传输协议(Hypertext Transfer Protocol),HTTP 是一个在计算机世界里专门在两点之间传输文字.图片.音频.视频等超 ...
- 面试官最爱问的并发问题
转载自 面试官最爱问的并发问题 在Java相关的岗位面试中,很多面试官都喜欢考察面试者对Java并发的了解程度,而以volatile关键字作为一个小的切入点,往往可以一问到底,把Java内存模型(J ...
- 面试官最爱问的Redis(三)Redis的基本知识
面试官最爱问的redis,继续整理了Redis的学习笔记,动力节点的redis视频,13个小时搞定redis,笔记分享给大家. 视频资源:https://www.bilibili.com/video/ ...
- 面试官都在问 | Linux命令mpstat详解
面试官都在问 | Linux命令mpstat详解 1. mpstat的基本用法 mpstat的全称为Multiprocessor Statistics,是一款常用的多核CPU性能分析工具,用来实时查询 ...
- 阿里的面试官都喜欢问哪些问题?
作者:徐刘根 | 公众号:Java之间 金九银十是招聘的旺季,小编在这里也给大家整理了一套阿里面试官最喜欢问的问题或者出场率较高的面试题,助校招或者社招路上的你一臂之力! 首先我们需要明白一个事实,招 ...
最新文章
- 第十六届全国大学智能车竞赛华南赛区成绩汇总
- URL Collection
- 算法高级(4)-遗传算法(Genetic Algorithm)简介
- 枚举求解:试把一个正整数n拆分为若干个(不少于2个)连续正整数之和。例如:n=15,有3种拆分:15=1+2+3+4+5,15=4+5+6,15=7+8。 对于给定的正整数n,求出所有符合这种拆分要求
- moss2007-搜索服務
- java 容易犯错_写Java程序最容易犯错误有哪些呢?
- 三自由度机械手腕设计机构设计
- 向武 清华大学 计算机,双胞胎兄弟向威、向武同时考上清华大学
- 【JAVASE】多线程编程基础
- 卧槽!迅雷的代码结构竟然被扒了精光!
- V4L2 驱动层分析
- 2018 Github优秀开源项目整理
- 【win10自定义默认应用】
- JavaScript —— JSchallenger Arrays 数组练习(测试一下你的 JS 数组基础)【专题二】
- 5G LAN — 技术实现原理
- 经典伴读_GOF设计模式_结构型模式
- can和could的用法_can与could用法归纳
- Linux系统——程序员跳槽必备
- 深度学习常见名词概念:Sota、Benchmark、Baseline、端到端模型、迁移学习等的定义
- echarts r 地图_pyecharts自定义地图