.NET高级面试指南专题二十七【享元模式介绍,通过共享对象来最大程度地减少内存使用和提高性能】

享元模式是一种结构型设计模式,旨在通过共享对象来最大程度地减少内存使用和提高性能。

在享元模式中,对象被分为两种部分:内部状态(intrinsic state)和外部状态(extrinsic state)。内部状态是对象共享的部分,而外部状态是对象的变化部分,它们在对象被创建后可以被改变。

下面是享元模式的一些优点和缺点:

优点:

  • 节省内存:通过共享对象,可以减少系统中的内存占用。
  • 提高性能:减少对象的数量可以提高系统的性能,尤其是在需要大量相似对象时。
  • 简化对象的创建:通过享元工厂(Flyweight Factory)来管理共享对象的创建,可以简化对象的创建过程。

缺点:

  • 复杂性增加:引入了内部状态和外部状态的概念,增加了系统的复杂性。
  • 对象状态共享:共享对象的状态可能会导致对象之间的相互影响,需要额外的逻辑来管理状态的改变。
  • 不适合所有情况:并不是所有对象都适合被共享,有时候会因为共享而增加系统的复杂性。

演示代码:

csharp 复制代码
using System;
using System.Collections.Generic;

// 享元接口
interface IShape
{
    void Draw(string color);
}

// 具体享元类
class Circle : IShape
{
    private string _name;

    public Circle(string name)
    {
        this._name = name;
    }

    public void Draw(string color)
    {
        Console.WriteLine($"Drawing {_name} with color {color}");
    }
}

// 享元工厂
class ShapeFactory
{
    private Dictionary<string, IShape> _shapes = new Dictionary<string, IShape>();

    public IShape GetShape(string name)
    {
        if (!_shapes.ContainsKey(name))
        {
            _shapes[name] = new Circle(name);
        }
        return _shapes[name];
    }
}

class Program
{
    static void Main(string[] args)
    {
        ShapeFactory shapeFactory = new ShapeFactory();

        // 绘制红色圆形
        IShape circle1 = shapeFactory.GetShape("Circle");
        circle1.Draw("Red");

        // 绘制蓝色圆形
        IShape circle2 = shapeFactory.GetShape("Circle");
        circle2.Draw("Blue");

        // 绘制绿色圆形
        IShape circle3 = shapeFactory.GetShape("Circle");
        circle3.Draw("Green");
    }
}

Circle 类表示具体的享元类,ShapeFactory 类是享元工厂,负责创建并管理共享的对象。通过共享相同的圆形对象,可以减少内存使用和提高性能。

相关推荐
Warren983 小时前
Pytest Fixture 作用域详解:Function、Class、Module、Session 怎么选
面试·职场和发展·单元测试·pytest·pip·模块测试·jira
努力学算法的蒟蒻3 小时前
day73(2.1)——leetcode面试经典150
面试·职场和发展
Warren983 小时前
接口测试理论
docker·面试·职场和发展·eureka·ansible
cyforkk4 小时前
13、Java 基础硬核复习:泛型(类型安全)的核心逻辑与面试考点
java·开发语言·面试
试着5 小时前
【huawei】机试
华为·面试·机试·手搓代码
编程彩机5 小时前
互联网大厂Java面试:从分布式事务到微服务优化的技术场景解读
java·spring boot·redis·微服务·面试·kafka·分布式事务
编程彩机5 小时前
互联网大厂Java面试:从Spring WebFlux到分布式事务的技术场景解析
java·微服务·面试·分布式事务·spring webflux
kogorou0105-bit5 小时前
前端设计模式:发布订阅与依赖倒置的解耦之道
前端·设计模式·面试·状态模式
闻哥5 小时前
深入理解 ES 词库与 Lucene 倒排索引底层实现
java·大数据·jvm·elasticsearch·面试·springboot·lucene
indexsunny6 小时前
互联网大厂Java面试实战:从Spring Boot到Kafka的技术与业务场景解析
java·spring boot·redis·面试·kafka·技术栈·microservices