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

相关推荐
西安邮电大学16 小时前
有关数组的经典算法题
java·后端·其他·算法·面试
触底反弹16 小时前
一文彻底搞懂 JavaScript 栈和队列(建议收藏)
javascript·算法·面试
AI人工智能+电脑小能手17 小时前
【大白话说Java面试题 第113题】【并发篇】第13题:说一下乐观锁的优点和缺点?
java·开发语言·面试
Mahir0817 小时前
HashMap 底层原理深度解密:从数据结构到 JDK1.7/1.8 演进全解
java·后端·面试·hashmap
uhakadotcom17 小时前
get_event_loop(),和 get_running_loop() + ThreadPoolExecutor 有啥区别
后端·面试·github
牛油果子哥q17 小时前
二叉树(Binary Tree)零基础精讲,树基础概念、树形分类、核心性质、递归/层序遍历、完整代码与面试考点全解
c++·面试·数据挖掘
牛油果子哥q18 小时前
队列(Queue)深度精讲,先进先出原理、顺序/链式/循环队列、STL queue底层、栈队列互模拟与面试考点全解
开发语言·c++·面试
ceclar12318 小时前
C#字节流与字符流
算法·c#·.net
Mahir0818 小时前
ConcurrentHashMap 底层原理深度解密:从分段锁到 CAS + 红黑树的演进全解
java·面试·concurhashmap