设计模式——享元模式具体解释

0. 前言

写在最前面,本人的设计模式类博文,建议先看博文前半部分的理论介绍。再看后半部分的实例分析。最后再返回来复习一遍理论介绍,这时候你就会发现我在重点处标红的用心,对于帮助你理解设计模式有奇效哦~本文原创。转载请注明出处为SEU_Calvin的博客

春运买火车票是一件疯狂的事情。同一时刻会有大量的查票请求涌向server。server必须做出应答来满足我们的购票需求。试想。这些请求包括着大量的反复,比方A地到B的车票情况。假设每次都反复创建一个车票查询结果的对象,那么GC任务将很繁重。影响性能,这就用到了我们的享元模式

当然也会有不反复的请求。比方我想购买从A地到B地的高铁票。而你想买从A地到B地的动车票


1. 享元模式模式介绍

享元模式定义:

享元模式以共享的方式高效地支持大量的细粒度对象。享元模式中仅仅有内部状态(不会随环境发生改变)能够共享,在春运的样例中代表详细的A地到B外部状态(随环境改变)不可共享,在样例中代表客户想购买从A地到B地的高铁票还是动车票

 

享元模式的使用场景:

假设一个应用程序须要创建大量的类似对象。须要用对象缓冲池时。

 

享元模式包括的角色:


1抽象享元Flyweight:享元对象抽象基类或接口。

2详细享元ConcreteFlyweight:实现抽象享元类。

3享元工厂FlyweightFactory:享元模式的核心模块。负责管理享元对象池、创建享元对象,保证享元对象能够被系统适当地共享

当一个client对象调用一个享元对象的时候。享元工厂角色会检查系统中是否已经有一个符合要求的享元对象,假设已有,享元工厂角色就提供这个已有的享元对象;假设没有就创建一个。


2. 享元模式模式实例介绍

通过上面给出的角色类,我们能够把文章開始时的样例实现一下,代码也比較简单:

/*
*@SEU_Calvin
*@2016/12/31
*/
//抽象享元类
public interface Ticket{//显示票价。參数为列车类型 
public void showPrice(String type);
}//详细享元类
public class ConcreteTicket implements Ticket {
String from;
String to;
public ConcreteTicket(String from,String to){this.from = from;this.to = to;
}@Override  
public void showPrice(String type){
if(type.equals("Gaotie")){System.out.println("从"+from+"到"+to+"的高铁票价为200元");
}else{System.out.println("从"+from+"到"+to+"的动车票价为120元");
}
}
}  //享元工厂类
public class TicketFactory{
static Map<String,Ticket> map= new ConcurrentHashMap< String,Ticket >();
public static Ticket getTicket(String from,String to){String key = from+to;if(map.containsKey(key)){System.out.println("使用缓存查询"+key);return map.get(key);
}else{System.out.println("创建对象查询"+key);Ticket ticket = new ConcreteTicket(from,to);map.put(key, ticket);return ticket;
}
}
}//使用时
TicketFactory. getTicket("南京","杭州").showPrice("Gaotie");
TicketFactory. getTicket("南京","杭州").showPrice("Dongche");


从上面代码能够看出,我们利用了Map避免了大量查询南京到杭州列车信息相关的ConcreteTicket实例对象的创建。避免了频繁GC的发生。

从输出结果也能够看出第二次查询即从缓存中获取到ConcreteTicket对象。

在本例中内部状态就是从南京到杭州,外部状态是列车类型和价格,价格会随着列车类型变化


在JDK中的String的相关属性也符合了享元模式的实现原则,这就涉及到了常量池的概念,详细的已经在从JVM角度比較equals和==的差别一文中介绍过了。感兴趣的同学能够參考。


3. 享元模式的优缺点比較

享元模式的长处:

享元模式大幅度地减少内存中对象的数量,提高了程序的性能。

 享元模式的缺点:

1)为了使对象能够共享。须要将一些状态外部化,这使得程序的逻辑复杂化。

2)享元模式须要额外维护对象缓存池。



转载于:https://www.cnblogs.com/lytwajue/p/7395750.html

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/282638.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

OpenStack Nova计算服务管理(四)

作者&#xff1a;李晓辉联系方式: Xiaohui_lifoxmail.com环境介绍类型控制节点和计算节点等在一起&#xff0c;形成all-in-one内存8G硬盘200G网卡2块计算服务概览使用OpenStack计算服务来托管和管理云计算系统。OpenStack计算服务是基础设施即服务(IaaS)系统的主要部分&#xf…

miui替换官方文件解决无服务器,miui 关掉云服务器

miui 关掉云服务器 内容精选换一换本节操作介绍Linux云服务器切换密钥登录为密码登录的操作步骤。使用密钥登录Linux云服务器&#xff0c;设置root密码。sudo passwd root若密钥文件丢失或损坏&#xff0c;请参考Linux云服务器如何进入单用户模式重置root密码&#xff0c;重置r…

PHP-高并发和大流量的解决方案

一 高并发的概念 在互联网时代&#xff0c;并发&#xff0c;高并发通常是指并发访问。也就是在某个时间点&#xff0c;有多少个访问同时到来。 二 高并发架构相关概念 1、QPS (每秒查询率) : 每秒钟请求或者查询的数量&#xff0c;在互联网领域&#xff0c;指每秒响应请求数…

原型

2019独角兽企业重金招聘Python工程师标准>>> 什么是原型&#xff1a; 对象与对象之间的关系 转载于:https://my.oschina.net/u/2285087/blog/854377

JavaScript中数组slice和splice的对比小结

前言 今天重温了一下Javascript&#xff0c;看到了数组的方法&#xff0c;其中有两个比较相似的方法——splice和splice&#xff0c;看着很像&#xff0c;就是多了一个p&#xff0c;但是用法却相当不一样。 在使用中&#xff0c;可以通过选择一个具有强语义表达性的 API 来减少…

存储服务器的操作系统,存储服务器是什么操作系统

存储服务器是什么操作系统 内容精选换一换镜像服务提供了私有镜像的全生命周期管理能力&#xff0c;主要包括创建私有镜像&#xff0c;复制、共享或导出私有镜像等操作&#xff0c;您可以根据实际场景选择合适的方法&#xff0c;并结合弹性云服务器、对象存储等周边服务完成业务…

优化--减少HTTP请求

一、 图片地图 (将几张图片合为一张,根据用户点击的位置发送不同请求,减少了图片的请求数量) 案例所在位置:http://stevesouders.com/hpws/imagemap.php 二、css精灵(和图片地图功能相似,都是将几张图片合并在一起,根据位置发送不同请求) 这里不做具体使用介绍,百度有此方面内…

软件负载均衡

一、软件负载均衡概述 硬件负载均衡性能优越&#xff0c;功能全面&#xff0c;但是价格昂贵&#xff0c;一般适合初期或者土豪级公司长期使用。因此软件负载均衡在互联网领域大量使用。常用的软件负载均衡软件有Nginx&#xff0c;Lvs&#xff0c;HaProxy等。本文参考大量文档&a…

JAVA多线程之先行发生原则

一、引子   如果java内存模型中所有的有序性都仅仅依靠volatile和synchronized来完成&#xff0c;那么有一些操作会变得很繁琐&#xff0c;但我们在编写java并发代码时并未感觉到这一点&#xff0c;这是因为java语言中有个先行发生原则&#xff08;happens-before&#xff09…

git工具 将源码clone到本地指定目录的三种方式

git工具 将源码clone到本地指定目录的三种方式 CreationTime--2018年7月27日15点34分 Author:Marydon 1.情景展示 运行git-bash.exe&#xff0c;输入命令&#xff1a;git clone 下载源码地址-->回车&#xff0c;结果发现项目被下载到了&#xff0c;git工具的安装目录下 如何…

[摘]全文检索引擎Solr系列—–全文检索基本原理

原文链接--http://www.importnew.com/12707.html 全文检索引擎Solr系列—–全文检索基本原理 2014/08/18 | 分类&#xff1a; 基础技术, 教程 | 2 条评论 | 标签&#xff1a; solr 分享到&#xff1a; 64 本文作者&#xff1a; ImportNew - 刘志军 未经许可&#xff0c;禁止转载…

优化-浏览器缓存和压缩优化

一、减少HTTP请求 1.图片地图&#xff1a; 假设导航栏上有五幅图片&#xff0c;点击每张图片都会进入一个链接&#xff0c;这样五张导航的图片在加载时会产生5个HTTP请求。然而&#xff0c;使用一个图片地图可以提高效率&#xff0c;这样就只需要一个HTTP请求。 服务器端图片…

汇新杯┃拼多多黄峥:普通的创业者,不普通的朋友圈_创成汇

本月26日晚&#xff0c;拼多多在美国纳斯达克上市&#xff0c;开盘后便持续走高&#xff0c;收涨高达40.53%&#xff0c;这家从成立到上市不过短短2年10个月的企业&#xff0c;是近四年来最大中概股IPO。拼多多创始人黄峥身家一夜暴涨到138.5亿美元。在拼多多之前&#xff0c;黄…

NCC CAP 6.2 版本正式发布

原文&#xff1a;https://www.cnblogs.com/savorboard/p/cap-6-2.html作者&#xff1a;杨晓东前言今天&#xff0c;我们很高兴宣布 CAP 发布 6.2 版本正式版&#xff0c;在这个版本中我们主要做了一些功能优化&#xff0c;以及针对目前已经发现的几个 BUG 进行了修复了。那么&a…

pdksh 包

安装oracle gi&#xff0c;rac 时经常会碰到 pdksh 的检测失败&#xff0c;可以从这个网站下载需要的包 http://rpm.pbone.net/ rpm -q ksh-* rpm -e ksh-* rpm -ivh ./pdksh* 或者参考 Requirements for Installing Oracle 11gR2 RDBMS on RHEL6 or OL6 64-bit (x86-64) (文…

sysctl.conf工作原理

2019独角兽企业重金招聘Python工程师标准>>> sysctl.conf工作原理 sysctl命令被用于在内核运行时动态地修改内核的运行参数&#xff0c;可用的内核参数在目录/proc/sys中。它包含一些TCP/IP堆栈和虚拟内存系统的高级选项&#xff0c; 这可以让有经验的管理员提高引人…

CDN加速

一、CDN的概念 全称是Content Delivery Network&#xff0c;即内容分发网络。 其基本思路是: 尽可能避开互联网上有可能影响数据传输速度和稳定性的瓶颈和环节&#xff0c;使内容传输的更快、更稳定。 通过在网络各处放置节点服务器所构成的在现有的互联网基础之上的一层智…

修复删除/var/lib/dpkg目录后,无法使用apt-get命令问题

2019独角兽企业重金招聘Python工程师标准>>> Unfortunately Ive deleted dpkg directory while removing the lock. By mistake I typed rootsam:~$ rm -r /var/lib/dpkgNow when I am trying to install/uninstall packages it shows me following error. E: Could…

动态加载vs静态加载

动态加载&#xff1a; 1&#xff1a;灵活&#xff0c;可以在需要的时候用LoadLibrary进行加载&#xff0c;在不需要的时候用FreeLibrary进行卸载&#xff0c;这样可以不必占用内存。2&#xff1a;可以在没有dll时候发现&#xff0c;而不致程序报错。3&#xff1a;加载程序中有条…

Webpack前端打包工具

一、安装 安装Webpack之前需要安装nodejs&#xff0c;然后用npm安装: $ npm install webpack -g &nsbp;运行以上命令就将Webpack安装到了全局环境中。 但是通常我们会将Webpack只安装到项目的依赖中: $ cd /www/webpack_demo1 // 进入项目目录&#xff0c;确保该目录…