`
cakin24
  • 浏览: 1383014 次
  • 性别: Icon_minigender_1
  • 来自: 西安
社区版块
存档分类
最新评论

享元模式一五子棋游戏

阅读更多

一模式定义

享元模式,以共享的方式高效地支持大量的细粒度对象。通过复用内存中已存在的对象,降低系统创建对象实例的性能消耗。享元的英文是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在系统设计中,对象实例进行分类后,发现真正有区别的分类很少的时候。

 

六享元模式静态类图



 

  • 大小: 96 KB
  • 大小: 61.5 KB
  • 大小: 46.5 KB
1
0
分享到:
评论

相关推荐

    享元模式,内含可运行代码和解释

    享元模式是一种经典的设计模式,属于结构型模式,它的核心思想是通过共享已经存在的对象来减少内存中的对象数量,从而提高系统性能。在许多场景下,特别是计算机编程中,我们可能会遇到大量的相似对象,比如在图形...

    设计模式-享元模式(讲解及其实现代码)

    享元模式是一种结构型设计模式,它通过共享已有对象来减少内存中对象的数量,从而达到降低系统内存占用、提高性能的目的。在软件工程中,当系统中存在大量相似或重复的对象时,享元模式尤为适用。 享元模式的核心是...

    享元模式的分析以及实际应用.docx

    享元模式是一种优化资源利用的设计模式,主要用于减少创建和管理对象的数量,以达到节省内存的目的。在软件工程中,尤其是在处理大量相似对象时,享元模式能够显著提高系统的性能。享元模式通过共享那些可以共享的...

    享元模式1

    3. 由于享元模式需要额外维护一个保存享元的数据结构,所以应当在有足够多的享元实例时才值得使用享元模式。 拓展: a) 单纯享元模式这种享元模式中的所有的具体享元类都是可以共享的,不存在非共享的具体享元类,...

    享元模式介绍

    设计模式中的享原模式技术入门,可用于各种说明场合,一看就会哦

    装饰器模式、原型模式、享元模式

    装饰器模式、原型模式和享元模式是软件设计模式中的三种重要模式,它们在实际项目开发中被广泛应用,以提高系统的性能和可维护性。下面将详细解释这三种设计模式的概念、应用场景及其实现方式。 **装饰器模式...

    Java 23种设计模式15享元模式.pdf

    享元工厂类是享元模式的核心,它维护一个享元池,当客户端请求享元对象时,享元工厂会先检查享元池中是否存在满足需求的享元对象,如果存在则直接返回;若不存在,则创建一个新的享元对象,将其添加到享元池中并返回...

    设计模式专题之(十二)享元模式---设计模式享元模式示例代码(python--c++)

    享元模式是一种结构型设计模式,它通过共享已有对象来减少内存中对象的数量,从而达到提高系统性能的目的。在大型软件系统中,特别是在处理大量相似对象时,享元模式能够有效地减少内存开销,提高系统运行效率。在这...

    c++-设计模式之享元模式(Flyweight)

    享元模式(Flyweight Pattern)是一种结构型设计模式,用于减少创建大量小对象所带来的内存开销。通过共享对象,享元模式能够有效地支持大量细粒度的对象,减少内存使用并提高性能。它常用于需要大量重复对象的场景...

    javascript 设计模式之享元模式原理与应用详解

    本文实例讲述了javascript 设计模式之享元模式。分享给大家供大家参考,具体如下: 享元模式说明 定义:用于解决一个系统大量细粒度对象的共享问题: 关健词:分离跟共享; 说明: 享元模式分单纯(共享)享元模式,...

    26享元模式.zip

    享元模式是一种优化资源使用的软件设计模式,它通过共享大量相似对象来减少内存消耗,尤其适用于那些创建大量对象且内存管理成为性能瓶颈的情况。在Java等面向对象编程语言中,享元模式通常用来提高系统效率,减少...

    设计模式之享元模式1

    在DOM层,享元模式可以用于事件处理,比如在一个大的容器元素中,而不是为每个子元素绑定事件处理器,而是为容器元素绑定一个事件处理器,然后通过事件冒泡来处理子元素的事件。这样可以减少DOM上的事件监听器数量,...

    【Java设计模式-源码】享元模式

    - Java中享元模式的一个实际应用可以在像Microsoft Word或Google Docs这样的文本编辑器中看到。这些应用程序使用享元模式来有效地管理内存,通过共享字符对象,显著减少了内存占用。在这样的应用程序中,文档中的每...

    第十四课 享元模式1

    享元模式是一种优化性能的结构性设计模式,主要解决在程序中大量相似对象导致的内存消耗问题。通过将对象的状态划分为内部状态和外部状态,享元模式能够减少实际需要创建的实例数量,从而提高系统效率。 内部状态是...

    四子棋游戏软件设计文档

    四子棋软件是由洪云鹏、张东辉和我共同开发的一款基于C#的游戏软件,采用GDI技术构建图形界面,提供双人对战和人机对弈两种模式。游戏界面直观,旨在提供一个互动且友好的用户体验。 1.2 项目背景与创新 在众多...

    java基础设计模式模式 - 享元模式.7z

    享元模式是一种优化资源使用的软件设计模式,尤其适用于对象创建成本较高或系统内存有限的场景。在Java编程中,享元模式通过共享已有对象来减少内存中的对象数量,从而提高性能。这种模式的核心是实现细粒度对象的...

    设计模式面面观(14):享元模式(Facade Pattern)-结构型模式

    设计模式面面观(14):享元模式(Facade Pattern)-结构型模式 http://blog.csdn.net/fanweiwei/archive/2008/04/25/2326692.aspx

    享元模式简介和java代码实现

    享元模式是一种优化资源利用的设计模式,主要用于减少大量相似对象的创建,从而降低内存消耗和提高系统性能。在享元模式中,对象的状态分为两部分:内部状态和外部状态。内部状态是可以共享的部分,不会随对象的实例...

    C++设计模式之享元模式(Flyweight)

    享元模式的实现需要一个享元工厂来统一管理对象的生成和输出,享元工厂是实现享元模式的关键。享元工厂负责创建和管理享元对象,提供了一个共享对象池,供程序员使用共享对象,减少对象的创建数量。 在C++中,享元...

    GomokuGame(“四子棋”或“五子棋”两种模式).rar

    最终的exe游戏可以选择五子棋或四子棋两种模式,五子棋/四子棋/C语言/C++/MFC。 最终的exe游戏可以选择五子棋或四子棋两种模式,五子棋/四子棋/C语言/C++/MFC。 最终的exe游戏可以选择五子棋或四子棋两种模式,...

Global site tag (gtag.js) - Google Analytics