定義
享元模式(FlyWeight),運用共享技術有效的支持大量細粒度的對象。
典型的享元模式的例子為文書處理器中以圖形結構來表示字元。一個做法是,每個字形有其字型外觀, 字模 metrics,和其它格式資訊,但這會使每個字元就耗用上千位元組。取而代之的是,每個字元參照到一個共享字形物件,此物件會被其它有共同特質的字元所分享;只有每個字元(檔案中或頁面中)的位置才需要另外儲存。
結構
兩個狀態
內蘊狀態存儲在享元內部,不會隨環境的改變而有所不同,是可以共享的。
外蘊狀態是不可以共享的,它隨環境的改變而改變的,因此外蘊狀態是由客戶端來保持(因為環境的變化是由客戶端引起的)。
UML結構圖
![享元模式](/img/5/4c9/wZwpmL0gTOzEDOxMjN2UzM1UTM1QDN5MjM5ADMwAjMwUzLzYzLxczLt92YucmbvRWdo5Cd0FmLwE2LvoDc0RHa.jpg)
(1) 抽象享元角色:為具體享元角色規定了必須實現的方法,而外蘊狀態就是以參數的形式通過此方法傳入。在Java中可以由抽象類、接口來擔當。
(2) 具體享元角色:實現抽象角色規定的方法。如果存在內蘊狀態,就負責為內蘊狀態提供存儲空間。
(3) 享元工廠角色:負責創建和管理享元角色。要想達到共享的目的,這個角色的實現是關鍵!
(4) 客戶端角色:維護對所有享元對象的引用,而且還需要存儲對應的外蘊狀態。
使用場景
如果一個應用程式使用了大量的對象,而這些對象造成了很大的存儲開銷的時候就可以考慮是否可以使用享元模式。
例如,如果發現某個對象的生成了大量細粒度的實例,並且這些實例除了幾個參數外基本是相同的,如果把那些共享參數移到類外面,在方法調用時將他們傳遞進來,就可以通過共享大幅度單個實例的數目。
示例
典型的享元模式的例子為文書處理器中以圖形結構來表示字元。一個做法是,每個字形有其字型外觀, 字模 metrics, 和其它格式資訊,但這會使每個字元就耗用上千位元組。取而代之的是,每個字元參照到一個共享字形物件,此物件會被其它有共同特質的字元所分享;只有每個字元(檔案中或頁面中)的位置才需要另外儲存。以下程式用來解釋上述的檔案例子。這個例子用來解釋享元模式利用只載立執行立即小任務所必需的資料,因而減少記憶體使用量。