.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 类是享元工厂,负责创建并管理共享的对象。通过共享相同的圆形对象,可以减少内存使用和提高性能。

相关推荐
发现一只大呆瓜1 天前
Vite凭什么这么快?3分钟带你彻底搞懂 Vite 热更新的幕后黑手
前端·面试·vite
Patrick_Wilson1 天前
知识沉淀的四层模型:从个人笔记到企业资产,让文档真正长出复利
面试·程序员·ai编程
rockey6271 天前
AScript异步执行与await关键字
c#·.net·script·eval·expression·异步执行·动态脚本
橙序员小站1 天前
人人都在鼓吹的OPC,我想给你泼盆冷水
面试·创业
c++之路1 天前
享元模式(Flyweight Pattern)
享元模式
叫我少年1 天前
ASP.NET Core 最小 API 快速参考
.net·api
青山师1 天前
二叉树与BST深度解析:遍历算法与平衡策略
数据结构·算法·面试·二叉树·算法与数据结构·java面试·数据结构与算法分析
绝知此事1 天前
【算法突围 03】核心算法思想:分治/递归/动态规划与 LeetCode 高频真题解析
算法·leetcode·面试·动态规划
Wanderer X1 天前
【面试】HR
面试
jiayong231 天前
前端面试题库 - ES6+新特性篇
前端·面试·es6