摘要:享元模式享元模式是一種優化程序性能的模式本質為減少對象創建的個數。
享元模式
享元模式是一種優化程序性能的模式, 本質為減少對象創建的個數。
以下情況可以使用享元模式:
有大量相似的對象, 占用了大量內存
對象中大部分狀態可以抽離為外部狀態
demo
某商家有 50 種男款內衣和 50 種款女款內衣, 要展示它們
方案一: 造 50 個塑料男模和 50 個塑料女模, 讓他們穿上展示, 代碼如下:
const Model = function(gender,underwear){ this.gender = gender this.underwear = underwear } Model.prototype.takephoto = function(){ console.log(`${this.gender}穿著${this.underwear}`); } for(let i=1;i<51;i++){ const maleModel = new Model("male",`第${i}款衣服`) maleModel.takephoto() } for(let i =1;i<51;i++){ const female = new Model("female",`第${i}款衣服`) female.takephoto() }
方案二: 造 1 個塑料男模特 1 個塑料女模特, 分別試穿 50 款內衣
const Model = function(gender){ this.gender = gender } Model.prototype.takephoto = function(){ console.log(`${this.gender}穿著${this.underwear}`) } const maleModel = new Model("male") const femaleModel = new Model("female") for(let i =1;i<51;i++){ maleModel.underwear = `第${i}款衣服` maleModel.takephoto() } for(let i =1; i<51;i++){ femaleModel.underwear = `第${i}款衣服` femaleModel.takephoto() }
對比發現: 方案一創建了 100 個對象, 方案二只創建了 2 個對象, 在該 demo 中, gender(性別) 是內部對象, underwear(穿著) 是外部對象。
當然在方案二的 demo 中, 還可以進一步改善:
1 一開始就通過構造函數顯示地創建實例, 可用工場模式將其升級成可控生成
2 在實例上手動添加 underwear 不是很優雅, 可以在外部多帶帶在寫個 manager 函數
const Model = function (gender) { this.gender = gender } Model.prototype.takephoto = function () { console.log(`${this.gender}穿著${this.underwear}`) } const modelFactory = (function () { // 優化第一點 const modelGender = {} return { createModel: function (gender) { if (modelGender[gender]) { return modelGender[gender] } return modelGender[gender] = new Model(gender) } } }()) const modelManager = (function () { const modelObj = {} return { add: function (gender, i) { modelObj[i] = { underwear: `第${i}款衣服` } return modelFactory.createModel(gender) }, copy: function (model, i) { // 優化第二點 model.underwear = modelObj[i].underwear } } }()) for (let i = 1; i < 51; i++) { const maleModel = modelManager.add("male", i) modelManager.copy(maleModel, i) maleModel.takephoto() } for (let i = 1; i < 51; i++) { const femaleModel = modelManager.add("female", i) modelManager.copy(femaleModel, i) femaleModel.takephoto() }
文章版權歸作者所有,未經允許請勿轉載,若此文章存在違規行為,您可以聯系管理員刪除。
轉載請注明本文地址:http://m.specialneedsforspecialkids.com/yun/106734.html
摘要:作者按每天一個設計模式旨在初步領會設計模式的精髓,目前采用和兩種語言實現。享元模式提醒我們將一個對象的屬性劃分為內部和外部狀態。 作者按:《每天一個設計模式》旨在初步領會設計模式的精髓,目前采用javascript和python兩種語言實現。誠然,每種設計模式都有多種實現方式,但此小冊只記錄最直截了當的實現方式 :) 個人技術博客-godbmw.com 歡迎來玩! 每周至少 1 篇原創...
摘要:作者按每天一個設計模式旨在初步領會設計模式的精髓,目前采用和兩種語言實現。享元模式提醒我們將一個對象的屬性劃分為內部和外部狀態。 作者按:《每天一個設計模式》旨在初步領會設計模式的精髓,目前采用javascript和python兩種語言實現。誠然,每種設計模式都有多種實現方式,但此小冊只記錄最直截了當的實現方式 :) 個人技術博客-godbmw.com 歡迎來玩! 每周至少 1 篇原創...
摘要:享元模式通過分析應用程序的對象,將其解析為內在數據和外在數據,減少對象數量,從而提高程序的性能。通過這種方式進行事件綁定,可以減少事件處理程序的數量,這種方式叫做事件委托,也是運用了享元模式的原理。事件處理程序是公用的內在部分,每個菜單項各 github 全文地址 : YOU-SHOULD-KNOW-JS JavaScript設計模式之外觀模式 概念 外觀模式:為一組復雜子系統接口提...
閱讀 2529·2021-09-24 10:29
閱讀 3810·2021-09-22 15:46
閱讀 2580·2021-09-04 16:41
閱讀 2986·2019-08-30 15:53
閱讀 1265·2019-08-30 14:24
閱讀 3058·2019-08-30 13:19
閱讀 2174·2019-08-29 14:17
閱讀 3526·2019-08-29 12:55