一模式定义
享元模式,以共享的方式高效地支持大量的细粒度对象。通过复用内存中已存在的对象,降低系统创建对象实例的性能消耗。享元的英文是Flyweight,表示特别小的对象,即细粒度对象。
二模式举例
1模式分析
我们借用五子棋游戏来说明这一模式。
2享元模式静态类图
3代码示例
3.1创建抽象棋子一AbstractChessman
package com.demo.flyweight.object; public abstract class AbstractChessman { // 棋子坐标 protected int x; protected int y; // 棋子类别(黑|白) protected String chess; public AbstractChessman(String chess) { this.chess = chess; } // 点坐标设置 public abstract void point(int x, int y); // 显示棋子信息 public void show() { System.out.println(this.chess + "(" + this.x + "," + this.y + ")"); } }
3.2创建黑子一BlackChessman
package com.demo.flyweight.object; public class BlackChessman extends AbstractChessman { /** * 构造方法 初始化黑棋子 */ public BlackChessman() { super("●"); System.out.println("--BlackChessman Construction Exec!!!"); } // 点坐标设置 @Override public void point(int x, int y) { this.x = x; this.y = y; // 显示棋子内容 show(); } }
3.3创建白子一WhiteChessman
package com.demo.flyweight.object; public class WhiteChessman extends AbstractChessman { /** * 构造方法 初始化白棋子 */ public WhiteChessman() { super("○"); System.out.println("--WhiteChessman Construction Exec!!!"); } // 点坐标设置 @Override public void point(int x, int y) { this.x = x; this.y = y; // 显示棋子内容 show(); } }
3.4创建棋子工厂一FiveChessmanFactory
package com.demo.flyweight.factory; import java.util.Hashtable; import com.demo.flyweight.object.AbstractChessman; import com.demo.flyweight.object.BlackChessman; import com.demo.flyweight.object.WhiteChessman; public class FiveChessmanFactory { // 单例模式工厂 private static FiveChessmanFactory fiveChessmanFactory = new FiveChessmanFactory(); // 缓存存放共享对象 private final Hashtable<Character, AbstractChessman> cache = new Hashtable<Character, AbstractChessman>(); // 私有化构造方法 private FiveChessmanFactory() { } // 获得单例工厂 public static FiveChessmanFactory getInstance() { return fiveChessmanFactory; } /** * 根据字符获得棋子 * * @param c * (B:黑棋 W:白棋) * @return */ public AbstractChessman getChessmanObject(char c) { // 从缓存中获得棋子对象实例 AbstractChessman abstractChessman = this.cache.get(c); if (abstractChessman == null) { // 缓存中没有棋子对象实例信息 则创建棋子对象实例 并放入缓存 switch (c) { case 'B': abstractChessman = new BlackChessman(); break; case 'W': abstractChessman = new WhiteChessman(); break; default: break; } // 为防止 非法字符的进入 返回null if (abstractChessman != null) { // 放入缓存 this.cache.put(c, abstractChessman); } } // 如果缓存中存在 棋子对象则直接返回 return abstractChessman; } }
3.5客户端实现一Client
package com.demo; import java.util.Random; import com.demo.flyweight.factory.FiveChessmanFactory; import com.demo.flyweight.object.AbstractChessman; /** * 主应用程序 * * @author */ public class Client { /** * @param args */ public static void main(String[] args) { // 创建五子棋工厂 FiveChessmanFactory fiveChessmanFactory = FiveChessmanFactory .getInstance(); Random random = new Random(); int radom = 0; AbstractChessman abstractChessman = null; // 随机获得棋子 for (int i = 0; i < 10; i++) { radom = random.nextInt(2); switch (radom) { // 获得黑棋 case 0: abstractChessman = fiveChessmanFactory.getChessmanObject('B'); break; // 获得白棋 case 1: abstractChessman = fiveChessmanFactory.getChessmanObject('W'); break; } if (abstractChessman != null) { abstractChessman.point(i, random.nextInt(15)); } } } }
4运行结果
--WhiteChessman Construction Exec!!!
○(0,2)
○(1,6)
--BlackChessman Construction Exec!!!
●(2,3)
○(3,14)
○(4,13)
○(5,8)
●(6,14)
●(7,0)
●(8,3)
○(9,8)
三享元模式的两种状态
- 内蕴状态:不会随环境的改变而改变,是存储在享元对象内部状态信息,困此内蕴状态是可以共享的,对于任何一个享元对象来讲,它的值是完全相同的。就像五子棋中的"黑子"和"白子",它代表的状态就是内蕴状态。
- 外蕴状态:它会随环境的改变而改变,因此不可以共享状态,对于不同的享元对象讲,它的值可能是不同的。享元对象的外蕴状态必须由客户端保存,在享元对象被创建之后,需要使用的时候再传入享元对象内部。就像五子棋的位置信息,代表的状态就是享元对象的外蕴状态。
所以,享元的外蕴状态和内蕴状态是两类相互独立的状态,彼此没关联。
四该模式设计原则
1共享细粒度对象,降低内存空间。
2有效地隔离系统中变化部分和不变部分。
五使用场合
1当系统中某个对象类型的实例较多的时候。
2在系统设计中,对象实例进行分类后,发现真正有区别的分类很少的时候。
六享元模式静态类图
相关推荐
享元模式是一种软件设计模式,它的主要目的是为了提高性能,减少对象的创建,尤其是在大量相似对象需要被创建的情况下。在给定的咖啡店案例中,享元模式的应用可以帮助优化内存使用,避免为每杯咖啡的配料表分配独立...
享元模式是一种结构型设计模式,它通过共享已有对象来减少系统中对象的数量,从而达到降低内存占用的目的。在软件工程中,当一个系统需要处理大量相似对象时,享元模式能够有效地提升性能,尤其在处理轻量级对象时...
享元模式是软件设计模式中的一种结构型模式,它的核心思想是通过共享已经存在的对象来减少内存中的对象数量,从而提高系统性能。在Java中,享元模式常用于处理大量相似对象的场景,例如在图形界面中绘制大量相似的...
享元模式是一种结构型设计模式,它通过共享已有对象来减少内存中对象的数量,从而达到降低系统内存占用、提高性能的目的。在软件工程中,当系统中存在大量相似或重复的对象时,享元模式尤为适用。 享元模式的核心是...
享元模式是一种优化资源利用的设计模式,主要用于减少创建和管理对象的数量,以达到节省内存的目的。在软件工程中,尤其是在处理大量相似对象时,享元模式能够显著提高系统的性能。享元模式通过共享那些可以共享的...
游戏开发-基于QT和C++开发的六子棋游戏对战项目源码(支持双人模式、人机对战等).zip游戏开发-基于QT和C++开发的六子棋游戏对战项目源码(支持双人模式、人机对战等).zip游戏开发-基于QT和C++开发的六子棋游戏对战...
本项目是一款基于C#多语言开发的房卡类棋牌游戏大厅源码,整合了斗地主、3D麻将(包括红中麻将、血战麻将、广东麻将等)及跑得快等多种益智棋牌游戏。该游戏大厅支持多种游戏模式,并具备茶馆俱乐部功能,共包含2767...
享元模式(Flyweight Pattern)是软件设计中的一种结构型设计模式,它通过共享技术来支持大量细粒度的对象,以此来降低内存中对象的数量。在PHP中实现享元模式,可以帮助我们优化程序性能,特别是在对象数目过多时,...
装饰器模式、原型模式和享元模式是软件设计模式中的三种重要模式,它们在实际项目开发中被广泛应用,以提高系统的性能和可维护性。下面将详细解释这三种设计模式的概念、应用场景及其实现方式。 **装饰器模式...
本文实例讲述了javascript 设计模式之享元模式。分享给大家供大家参考,具体如下: 享元模式说明 定义:用于解决一个系统大量细粒度对象的共享问题: 关健词:分离跟共享; 说明: 享元模式分单纯(共享)享元模式,...
享元模式(Flyweight Pattern)是结构型模式的一种,主要用于减少大量相似对象的内存占用,提高系统的性能和效率。 模式定义 享元模式的定义是:运用共享技术有效地支持大量细粒度的对象。该模式将一个对象的状态...
享元模式是一种优化资源使用的软件设计模式,尤其适用于大量对象的场景,通过共享技术来有效支持大量细粒度的对象。这种模式的核心在于减少内存中对象的数量,以提高系统性能。在"最简单的简单享元模式"中,我们将...
享元模式是一种结构型设计模式,它通过共享技术来有效支持大量细粒度对象的复用,从而减少系统中对象的数量,降低系统的内存消耗。在软件工程中,当我们需要创建大量相似但略有差异的对象时,享元模式可以提供一种...
局域网棋牌游戏服务器+客户端是针对局域网环境设计的一款集成了服务器和客户端的游戏系统,主要服务于玩家在有限的网络范围内进行多人对战的棋牌游戏体验。这类系统通常包含以下几个核心组成部分: 1. **服务器端**...
享元模式(Flyweight)是23种设计模式之一,属于结构型设计模式。该模式通过共享技术,有效地支持大量细粒度对象的复用。享元模式的目的是为了减少创建对象的数量,以减少内存占用和提高性能。 ### 细粒度对象 享元...
享元模式是一种优化资源使用的软件设计模式,尤其适用于对象创建成本较高或系统内存有限的情况。在Java、C#等面向对象编程语言中,享元模式通过共享已经存在的对象,而不是频繁地创建新对象,来减少内存消耗。此模式...
- Java中享元模式的一个实际应用可以在像Microsoft Word或Google Docs这样的文本编辑器中看到。这些应用程序使用享元模式来有效地管理内存,通过共享字符对象,显著减少了内存占用。在这样的应用程序中,文档中的每...
四子棋软件是由洪云鹏、张东辉和我共同开发的一款基于C#的游戏软件,采用GDI技术构建图形界面,提供双人对战和人机对弈两种模式。游戏界面直观,旨在提供一个互动且友好的用户体验。 1.2 项目背景与创新 在众多...
享元模式是一种优化资源利用的设计模式,主要用于减少大量相似对象的创建,从而降低内存消耗和提高系统性能。在享元模式中,对象的状态分为两部分:内部状态和外部状态。内部状态是可以共享的部分,不会随对象的实例...
享元模式是一种结构型设计模式,它通过共享已有对象来减少系统中对象的数量,从而达到降低内存消耗和提高性能的目的。在Java编程中,享元模式通常用于处理大量相似对象的场景,例如在图形界面、文本渲染或者数据库...