結構模式之一旨在透過與相似物件共享盡可能多的資料來減少記憶體使用。
它在處理大量相似物件時特別有用,因為為每個物件建立一個新實例在記憶體消耗方面會非常昂貴。
關鍵概念:
內在狀態:多個物件之間共享的狀態獨立於上下文,並且在不同物件之間保持相同。
外部狀態:每個物件唯一的、從客戶端傳遞的狀態。此狀態可能會有所不同,並且不會儲存在 蠅量級 物件中
主要參與者:
蠅量級:蠅量級 物件接收外部狀態並使用它的介面。
Concrete蠅量級:實作 蠅量級 並儲存內在狀態。
蠅量級Factory:管理蠅量級物件並確保介面共享,如果存在則傳回現有的蠅量級。
Client(如 Main 類別):維護 蠅量級 的引用,並在需要與 蠅量級 物件互動時提供外部狀態。
讓我們舉一個角色的享元物件的例子
假設我們有一個文字編輯器需要渲染大量文字。每個字元都可以表示為一個對象,但是為每個字元都有一個單獨的對象會浪費大量記憶體。相反,我們可以使用 蠅量級s 來共享代表每個字母的字元對象,並儲存外部狀態,例如外部的位置或格式
蠅量級
public interface 蠅量級 { public void display(int x, int y);//x, y are the extrinsic state of the 蠅量級 object }
具體蠅量
public class Character蠅量級 implements 蠅量級 { private char ch; public Character蠅量級(char c){ this.ch = c; } @Override public void display(int x ,int y){ System.out.println("[drawing character: "+this.ch+" at co-ordinates:("+x+","+y+")]"); } }
蠅量級Factory
public class 蠅量級Factory { private static HashMap<character> flyweights = new HashMap(); public static 蠅量級 get蠅量級(char c){ 蠅量級 flyweight = flyweights.getOrDefault(c,null); if(null==flyweight){ flyweight = new Character蠅量級(c); flyweights.put(c,flyweight); } return flyweight; } } </character>
主要
public class Main { public static void main(String args[]){ 蠅量級 flyweight1 = 蠅量級Factory.get蠅量級('a'); 蠅量級 flyweight2 = 蠅量級Factory.get蠅量級('b'); 蠅量級 flyweight3 = 蠅量級Factory.get蠅量級('a');// will use the same object that is referenced by flyweight1 flyweight1.display(1, 2);//'a' displayed at 1,2 flyweight2.display(3, 4);//'b' displayed at 3,4 flyweight3.display(5, 7); // 'a'(shared) displayed at 5,7 } }
輸出:
[drawing character: a at co-ordinates:(1,2)] [drawing character: b at co-ordinates:(3,4)] [drawing character: a at co-ordinates:(5,7)]
重點
缺點
複雜性:此模式會增加程式碼的複雜性,特別是在分別管理外部和內部狀態時。
開銷:如果要共享的物件很少,享元模式可能會引入不必要的複雜性,而不會顯著節省記憶體。
以上是蠅量級的詳細內容。更多資訊請關注PHP中文網其他相關文章!