23种设计模式,享元模式的概念优缺点以及JAVA代码举例

简介: 【4月更文挑战第6天】享元模式(Flyweight Pattern)是一种结构型设计模式,旨在通过共享技术有效地支持大量细粒度对象的重用。这个模式在处理大量对象时非常有用,特别是当这些对象中的许多实例实际上可以共享相同的状态时,从而可以减少内存占用,提高程序效率

享元模式(Flyweight Pattern)是一种结构型设计模式,旨在通过共享技术有效地支持大量细粒度对象的重用。这个模式在处理大量对象时非常有用,特别是当这些对象中的许多实例实际上可以共享相同的状态时,从而可以减少内存占用,提高程序效率。

享元模式的概念

享元模式通过将对象的状态分为内部状态和外部状态来工作:

  • 内部状态是存储在享元对象内部的,并且不会随环境的改变而有所不同,即它们是可以共享的。
  • 外部状态是根据场景而变化的,不能共享,应由客户端代码保存。

使用享元模式可以避免大量非常相似类的开销,在软件开发中尤其是游戏开发和文档编辑器的设计中广泛应用。

享元模式的优点

  1. 减少运行时对象实例的数量,节省内存,提高性能。
  2. 将许多“虚拟”对象的状态集中管理,可以外部控制。

享元模式的缺点

  1. 增加了系统的复杂性:需要分离出外部状态和内部状态,这使得程序的逻辑复杂化。
  2. 对外部状态的管理增加了系统的维护难度

Java代码示例

假设我们正在开发一个文档编辑器,需要大量的字符对象。使用享元模式,我们可以共享相同的字符实例,而不是为每个出现的字符创建一个新对象。

首先,定义一个Character享元类:

java复制代码

public class Character {
    private final char value;
    private final String color;
    private final String fontFamily;
    private final int fontSize;

    public Character(char value, String color, String fontFamily, int fontSize) {
        this.value = value;
        this.color = color;
        this.fontFamily = fontFamily;
        this.fontSize = fontSize;
    }

    public void display() {
        System.out.println(value + " [Color: " + color + ", FontFamily: " + fontFamily + ", FontSize: " + fontSize + "]");
    }
}

然后,创建一个工厂类来管理享元对象的创建和重用:

java复制代码

import java.util.HashMap;
import java.util.Map;

public class CharacterFactory {
    private final Map<String, Character> characters = new HashMap<>();

    public Character getCharacter(char value, String color, String fontFamily, int fontSize) {
        String key = value + "-" + color + "-" + fontFamily + "-" + fontSize;
        Character character = characters.get(key);
        if (character == null) {
            character = new Character(value, color, fontFamily, fontSize);
            characters.put(key, character);
        }
        return character;
    }
}

最后,客户端代码示例:

java复制代码

public class Editor {
    public static void main(String[] args) {
        CharacterFactory factory = new CharacterFactory();

        Character character1 = factory.getCharacter('a', "red", "Arial", 12);
        Character character2 = factory.getCharacter('b', "red", "Arial", 12);
        Character character3 = factory.getCharacter('a', "red", "Arial", 12);

        character1.display();
        character2.display();
        character3.display();
    }
}

在这个例子中,character1character3实际上是同一个对象的引用,因为它们的状态完全相同。通过享元模式,我们可以在处理成千上万的字符对象时节省大量的内存。

相关文章
|
15天前
|
Java API 开发工具
【Azure Developer】Java代码实现获取Azure 资源的指标数据却报错 "invalid time interval input"
在使用 Java 调用虚拟机 API 获取指标数据时,因本地时区设置非 UTC,导致时间格式解析错误。解决方法是在代码中手动指定时区为 UTC,使用 `ZoneOffset.ofHours(0)` 并结合 `withOffsetSameInstant` 方法进行时区转换,从而避免因时区差异引发的时间格式问题。
|
27天前
|
人工智能 监控 安全
智慧工地解决方案,java智慧工地程序代码
智慧工地系统融合物联网、AI、大数据等技术,实现对施工现场“人、机、料、法、环”的全面智能监控与管理,提升安全、效率与决策水平。
|
1月前
|
算法 IDE Java
Java 项目实战之实际代码实现与测试调试全过程详解
本文详细讲解了Java项目的实战开发流程,涵盖项目创建、代码实现(如计算器与汉诺塔问题)、单元测试(使用JUnit)及调试技巧(如断点调试与异常排查),帮助开发者掌握从编码到测试调试的完整技能,提升Java开发实战能力。
248 0
|
24天前
|
缓存 Java 开发者
Java 开发者必看!ArrayList 和 LinkedList 的性能厮杀:选错一次,代码慢成蜗牛
本文深入解析了 Java 中 ArrayList 和 LinkedList 的性能差异,揭示了它们在不同操作下的表现。通过对比随机访问、插入、删除等操作的效率,指出 ArrayList 在多数场景下更高效,而 LinkedList 仅在特定情况下表现优异。文章强调选择合适容器对程序性能的重要性,并提供了实用的选择法则。
|
4月前
|
设计模式 Java 数据库连接
【设计模式】【创建型模式】工厂方法模式(Factory Methods)
一、入门 什么是工厂方法模式? 工厂方法模式(Factory Method Pattern)是一种创建型设计模式,它定义了一个用于创建对象的接口,但由子类决定实例化哪个类。工厂方法模式使类的实例化延迟
130 16
|
4月前
|
设计模式 负载均衡 监控
并发设计模式实战系列(2):领导者/追随者模式
🌟 ​大家好,我是摘星!​ 🌟今天为大家带来的是并发设计模式实战系列,第二章领导者/追随者(Leader/Followers)模式,废话不多说直接开始~
127 0
|
4月前
|
设计模式 监控 Java
并发设计模式实战系列(1):半同步/半异步模式
🌟 ​大家好,我是摘星!​ 🌟今天为大家带来的是并发设计模式实战系列,第一章半同步/半异步(Half-Sync/Half-Async)模式,废话不多说直接开始~
113 0
|
4月前
|
设计模式 安全 Java
并发设计模式实战系列(12):不变模式(Immutable Object)
🌟 大家好,我是摘星!🌟今天为大家带来的是并发设计模式实战系列,第十二章,废话不多说直接开始~
96 0
|
4月前
|
设计模式 算法 Java
设计模式觉醒系列(04)策略模式|简单工厂模式的升级版
本文介绍了简单工厂模式与策略模式的概念及其融合实践。简单工厂模式用于对象创建,通过隐藏实现细节简化代码;策略模式关注行为封装与切换,支持动态替换算法,增强灵活性。两者结合形成“策略工厂”,既简化对象创建又保持低耦合。文章通过支付案例演示了模式的应用,并强调实际开发中应根据需求选择合适的设计模式,避免生搬硬套。最后推荐了JVM调优、并发编程等技术专题,助力开发者提升技能。