javascript 设计模式-----享元模式
四个轮子,一个方向盘,有刹车,油门,车窗,这些词首先让人联想到的就是一辆汽车。的确,这些都是是一辆车的最基本特征,或者是属性,我们把词语抽象出来,而听到这些词语的人把他们想象陈一辆汽车。在代码里面也是这样的,为了将所有的车辆统一描述,我们将车的特征抽象出来,作为一个理念,就像柏拉图说的那样,接下来,我们要这个理念描绘他,让人来认识。这也就是程序中的实例化:
function Car() { this.lunzi = 4; this.shache = 1; }//js中没有类概念,但是我们可以模拟出来。这样,Car就作为了构造函数了。
接下来我们来实例它,让柏拉图的理念在现象世界中得到展示:
var benchi = new Car();
benchi 这个变量就是一个实例了。作为一辆汽车,它有四个轮子(lunzi),一个刹车(shache)。但是问题来了:理念只有一个,但是实例有很多,如果实例太多会怎么样呢?就跟起初上帝造物一样,起初只有一个人,后来从亚当身上撤下肋骨一根做了夏娃,夏娃吃了禁果,人类繁衍,人一多,罪恶就多了。程序的世界里也是这样,对象实例化次数过多,会导致内存无限制的增长,性能可想而知。那么怎么样避免这样的情况出现呢?享元模式出现了。下面我们以一个地方的财政系统购买外国车辆为例,运用享元模式解答难题,这个传统的实现方法:
var Cars = function(id, lt, fxp, lhq, sc, zw, cp, pp, ys, jg, cc, dhy ) {
this.id = id;
this.lt = lt;//轮胎
this.fxp = fxp;//方向盘
this.lhq = lhq;//离合器
this.sc = sc;//刹车
this.zw = zw;//座位
this.cp = cp;//车牌
this.pp = pp;//品牌
this.ys = ys;//颜色
this.jg = jg;//价格
this.cc = d.cc;//车窗
this.dhy = d.dhy;//导航仪
}
接下来的事情很容易,一个一个实例化这个类:
var car 1 = new Car('x',x,x,x,x,x,x,x,x,x);
var car 2 = new Car('x',x,x,x,x,x,x,x,x,x);
var car 3 = new Car('x',x,x,x,x,x,x,x,x,x);
...............................
var car 100 = new Car('x',x,x,x,x,x,x,x,x,x);//终于完了!!!
但是车辆数量一多起来的话会出现内存过多的问题。我们可以看到,一辆车里面有很多属性比如刹车数量,车窗数量,座位数量是相同的,享元模式的核心思想就是把共同享有的基本元素抽象出来。来看看是如何实现的。
//享元模式
var flyWight = (function(window, undefined){//立即执行函数返回一个享元对象
var Cars = {};//这里是存储器,用存储所有的car对象
var Car = function(d) {//构造方法
this.id = d.id;
this.lt = d.lt;//轮胎
this.fxp = d.fxp;//方向盘
this.lhq = d.lhq;//离合器
this.sc = d.sc;//刹车
this.zw = d.zw;//座位
this.cc = d.cc;//车窗
this.dhy = d.dhy;//导航仪
}
Car.prototype.gmg = 'china';// 买家的国籍,这里适应定义一些公共属性,适用于所有车辆的公用属性,比如购买的国家,方便统一修改
Car.prototype = {//Car的原型类方法,上面提供了操作Car实例的一些方法,可以自己定义,卤煮在此只定义最基本的方法
set : function(n ,v) {
this[n] = v;
},
get : function(n) {
return this[v];
}
}
var _factory = function(d) {//构建实例工厂,以pp(品牌)为类构建Car类别,,此方法属于私有,外部无法调用。
if(!Cars[d.pp]) {
Cars[d.pp] = new Car(d);
}
return Cars[d.pp];//返回该品牌的类别
} var controlCar = {//享元对象
allCars : {},//另一个存储所有车辆的对象,
addCar : function(data) {//添加一辆车
if(this.allCars[data.id]) return this.allCars[data.id];
this.allCars[data.id] = {
id : data.id,
pp : data.pp,
ys : data.ys,
cp : data.cp,
buyTime : data.buyTime,
jg : data.jg,
car : _factory(data)
}
},
removeCar : function(data) {//删除一辆车
if(this.allCars[data.id]) {
this.allCars[data.id] = undefined;
}
},
getCar : function (id) {//获取一辆汽车
return this.allCars[id];
}
} return controlCar;//返回享元对象
})(window, undefined);
从以上的代码我们可以看到,利用汽车的品牌作为实例的对象而不是单一的某个汽车。因为品牌再多是不会超过汽车的总数的,所以我们实际上要实例的对象就是十几个甚至是几个对象而已。这样,在allCar所有的子集元素中,每一个都是一辆包含有品牌类别的对象字面量而不是Car的实例对象了,我们可以在Car的原型链中中编写很多方法操作它们,同时它(该对象)不会丧失作为一辆汽车的基本特征,而且还会保持自己私有(颜色,价格)等特征。这样我们就达到了减少实例对象的目的了。下面,我们来看看它们是是怎么被用到的。首先是数据,这里有八辆车,三个品牌的,所以只有有三个Car的实例对象:
var data = [
{id:1,lt:4,fxp:1,lhq:1,sc:1,zw:5,cp:'x1231',pp:'benchi', ys:'red', jg:200000, buyTime : '1999-08-20', cc : 6, dhy : 1},
{id:2,lt:4,fxp:1,lhq:1,sc:1,zw:5,cp:'x1232',pp:'benchi', ys:'black', jg:207000, buyTime : '1999-08-21', cc : 6, dhy : 1},
{id:3,lt:4,fxp:1,lhq:1,sc:1,zw:5,cp:'x1233',pp:'benchi', ys:'gray', jg:200000, buyTime : '1999-08-22', cc : 6, dhy : 1}, {id:4,lt:4,fxp:1,lhq:1,sc:1,zw:5,cp:'x4564',pp:'fute', ys:'yellow', jg:150000, buyTime : '1999-08-23', cc : 6, dhy : 1},
{id:5,lt:4,fxp:1,lhq:1,sc:1,zw:5,cp:'x4565',pp:'fute', ys:'black', jg:160000, buyTime : '1999-08-24', cc : 6, dhy : 1},
{id:6,lt:4,fxp:1,lhq:1,sc:1,zw:5,cp:'x4566',pp:'fute', ys:'gray', jg:109000, buyTime : '1999-08-25', cc : 6, dhy : 1}, {id:7,lt:4,fxp:1,lhq:1,sc:1,zw:5,cp:'x7897',pp:'baoma', ys:'black', jg:380000, buyTime : '1999-08-26', cc : 6, dhy : 1},
{id:8,lt:4,fxp:1,lhq:1,sc:1,zw:5,cp:'x7898',pp:'baoma', ys:'blue', jg:300000, buyTime : '1999-08-27', cc : 6, dhy : 1}
]
轮询通过模式封装:
for(var i=0; i<data.length; i++) {
flyWight.addCar(data[i]);
}
通过flyWight.getCar(id)你可以获得你想要的某一辆车,你可以用直接赋值的方法修改它的特殊属性;
flyWight.getCar('1').jg = 300000
也可以通过Car字段所包含的对象的私有方法处理一些实际上很少会改变的值:
flyWight.getCar('1').car.set('lt', 5)
当然,我们在这里的基础属性并不是私有的,你可以按照自己的想法来编写代码。
总结:享元模式的核心:1有基础单元共享的数据对象集合,2.构造工厂函数,3.存储实例对象的容器。你可以在基本思想上面发挥自己的想法,这里例举的只是一个很简单的例子。
javascript 设计模式-----享元模式的更多相关文章
- 读书笔记之 - javascript 设计模式 - 享元模式
本章探讨另一种优化模式-享元模式,它最适合于解决因创建大量类似对象而累及性能的问题.这种模式在javascript中尤其有用,因为复杂的javascript代码很快就会用光浏览器的所有可用内存,通过把 ...
- javascript设计模式——享元模式
前面的话 享元(flyweight)模式是一种用于性能优化的模式,“fly”在这里是苍蝇的意思,意为蝇量级.享元模式的核心是运用共享技术来有效支持大量细粒度的对象.如果系统中因为创建了大量类似的对象而 ...
- javascript设计模式-享元模式
享元模式采用一个共享来有效的支持大量细小粒度的对象,避免大量有相同内容的类的开销(如内存耗费),共享一个元类. 应用场景:页面存在大量的资源密集型对象:他们具备一些共性,可以分离出公共操作的数据. 一 ...
- 8. 星际争霸之php设计模式--享元模式
题记==============================================================================本php设计模式专辑来源于博客(jymo ...
- C++设计模式——享元模式
本文版权归果冻说所有,欢迎转载,但未经作者同意必须保留此段声明,且在文章页面明显位置给出原文链接,否则保留追究法律责任的权利.如果这篇文章对你有帮助,你可以请我喝杯咖啡. » 本文链接:http:// ...
- java设计模式——享元模式
一. 定义与类型 定义:提供了减少对象数量从而改善应用所需的对象结构的方式,运用共享技术有效地支持大量细粒度的对象 类型:结构性 二. 使用场景 (1) 常常应用于系统底层的开发,以便解决系统的性能 ...
- 【设计模式】Java设计模式 - 享元模式
Java设计模式 - 享元模式 不断学习才是王道 继续踏上学习之路,学之分享笔记 总有一天我也能像各位大佬一样 原创作品,更多关注我CSDN: 一个有梦有戏的人 准备将博客园.CSDN一起记录分享自己 ...
- [设计模式] javascript 之 享元模式;
享元模式说明 定义:用于解决一个系统大量细粒度对象的共享问题: 关健词:分离跟共享: 说明: 享元模式分单纯(共享)享元模式,以及组合(不共享)享元模式,有共享跟不共享之分:单纯享元模式,只包含共享的 ...
- [工作中的设计模式]享元模式模式FlyWeight
一.模式解析 Flyweight在拳击比赛中指最轻量级,即“蝇量级”或“雨量级”,这里选择使用“享元模式”的意译,是因为这样更能反映模式的用意.享元模式是对象的结构模式.享元模式以共享的方式高效地支持 ...
随机推荐
- Nginx配置proxy_pass
nginx配置proxy_pass,需要注意转发的路径配置 1.location /test/ { proxy_pass http://t6:8300; } 2.location /test/ { p ...
- odoo模块
odoo模块包括 业务对象,web控制器,数据文件,前面2个是Python模块,而数据文件则是odoo特有的文件,例如,odoo数据文件,web数据.这些数据文件在 __odoo__.py 进行定义, ...
- Apizza可以进行本地调试,也可以进行跨域调试,但是需要chrome插件
装Apizza Chrome插件 1 1. 进入Apizza官方网站.注册账号,进入控制台,可以看到提示安装chrome插件 2. 进入google app商店,搜索apiano 找到对于插件安装 ...
- int main(int argc,char* argv[])详解
argc是命令行总的参数个数 argv[]是argc个参数,其中第0个参数是程序的全名,以后的参数命令行后面跟的用户输入的参数, 比如: int main(int argc, ...
- VM安装OracleLinux
http://blog.csdn.net/highning/article/details/11556077 一步一步教你在VMware Workstation 10 安装 Oracle Linux ...
- 国内及Github优秀开发人员列表
自从入了Android软件开发的行道,解决问题和学习过程中免不了会参考别人的思路,浏览博文和门户网站成了最大的入口.下面这些列表取名为:国内及Github优秀开发人员列表,就是浏览后的成果. 虽然下述 ...
- 查找原始MySQL死锁ID
转载地址:http://yueliangdao0608.blog.51cto.com/397025/1180917 如果遇到死锁了,怎么解决呢?找到原始的锁ID,然后KILL掉一直持有的那个线程就可以 ...
- Win7下安装一个装逼文本编辑器Atom + activate-power-mode插件
Atom是Github推出的一个文本编辑器,搜索一下大概是给Web前端用的,最近比较火的是他的一个插件activate-power-mode,可以实现打字屏振效果. 用来装装逼还是挺适合的,本来想试试 ...
- 黑马程序员_Java基础:多线程总结
------- android培训.java培训.期待与您交流! ---------- 一.多线程的概念 进程和线程经常会被人混淆,那是因为对它们的概念不明确.就拿我们平时使用的操作系统来说,它是多任 ...
- [UCSD白板题] Pairwise Distinct Summands
Problem Introduction This is an example of a problem where a subproblem of the corresponding greedy ...