当前位置: 首页 > news >正文

C++ 设计模式:享元模式(Flyweight Pattern)

链接:C++ 设计模式
链接:C++ 设计模式 - 单例模式

享元模式(Flyweight Pattern)是一种结构型设计模式,它通过共享尽可能多的相同对象来减少内存使用和提高性能。享元模式适用于大量细粒度对象的场景,这些对象之间有很多相同的部分,可以通过共享来减少内存消耗。

1.问题分析

在开发中,尤其是在需要大量细粒度对象的场景中,内存使用和性能优化是两个重要的考虑因素。例如,在图形界面、文本编辑器、游戏开发等领域,可能会有大量相似或相同的对象需要频繁创建和使用。如果每次都创建新的对象,不仅会占用大量内存,还会导致性能下降。

为了解决这些问题,我们可以结合工厂方法模式和延迟初始化来实现享元模式。具体来说,我们可以定义一个工厂类,通过延迟初始化和独立工厂函数来动态创建和缓存具体的对象。

2.实现步骤:

  1. 定义享元接口:定义一个抽象的接口,包含一个执行方法。
  2. 实现具体享元类:实现享元接口,定义具体的类。
  3. 定义独立工厂函数:定义一个独立的工厂函数,用于根据类型动态创建具体的对象。
  4. 实现享元工厂:实现一个工厂类,通过延迟初始化和独立工厂函数来动态创建和缓存具体的对象。
  5. 客户端代码:使用享元工厂获取具体对象,并执行。

3.代码示例

以机器人舞蹈动作作为示例。

3.1.定义享元接口

// 享元接口
class DanceMove {public:virtual ~DanceMove() = default;virtual void execute() = 0;
};

3.2.实现具体享元类

// 具体享元类1,抬手动作
class RaiseHand : public DanceMove {public:void execute() override { std::cout << "Executing Raise Hand Move" << std::endl; }
};
// 具体享元类2,转身动作
class TurnAround : public DanceMove {public:void execute() override { std::cout << "Executing Turn Around Move" << std::endl; }
};
// 具体享元类3,踢腿动作
class KickLeg : public DanceMove {public:void execute() override { std::cout << "Executing Kick Leg Move" << std::endl; }
};

3.3.定义独立工厂函数

// 独立工厂函数
std::shared_ptr<DanceMove> createDanceMove(const std::string& type) {if (type == "RaiseHand") {return std::make_shared<RaiseHand>();} else if (type == "TurnAround") {return std::make_shared<TurnAround>();} else if (type == "KickLeg") {return std::make_shared<KickLeg>();} else {return nullptr;}
}

3.4.实现享元工厂类

// 享元工厂
class DanceMoveFactory {public:// 获取舞蹈动作std::shared_ptr<DanceMove> getDanceMove(const std::string& type) {auto it = danceMoveMap_.find(type);if (it != danceMoveMap_.end()) {return it->second;} else {// 创建动作std::shared_ptr<DanceMove> danceMove = createDanceMove(type);if (danceMove) {danceMoveMap_[type] = danceMove;return danceMove;} else {throw std::runtime_error("Dance move type not recognized: " + type);}}}private:std::unordered_map<std::string, std::shared_ptr<DanceMove>> danceMoveMap_;
};

3.5.客户端代码

// 客户端代码
int main() {DanceMoveFactory factory;try {// 获取并执行舞蹈动作auto raiseHand = factory.getDanceMove("RaiseHand");raiseHand->execute();auto turnAround = factory.getDanceMove("TurnAround");turnAround->execute();auto kickLeg = factory.getDanceMove("KickLeg");kickLeg->execute();// 再次获取舞蹈动作,验证是否共享了相同类型的动作对象auto raiseHand2 = factory.getDanceMove("RaiseHand");raiseHand2->execute();std::cout << "raiseHand address: " << raiseHand.get() << std::endl;std::cout << "raiseHand2 address: " << raiseHand2.get() << std::endl;// 尝试获取未注册的舞蹈动作auto unknownMove = factory.getDanceMove("UnknownMove");unknownMove->execute();} catch (const std::exception& e) {std::cerr << "Error: " << e.what() << std::endl;}return 0;
}
http://www.lryc.cn/news/512463.html

相关文章:

  • Docker+Portainer 离线安装
  • Linux第100步_Linux之设置LCD作为终端控制台和LCD背光调节
  • Chapter09 国际化i18n 和 数据校验:Validation
  • 活动预告 | Microsoft 安全在线技术公开课:通过扩展检测和响应抵御威胁
  • Unresolved plugin: ‘org.apache.maven.plugins:maven-site-plugin:3.12.1‘
  • 5个开源RAG框架对比
  • 活动预告 | Microsoft Power Platform 在线技术公开课:实现业务流程自动化
  • 【分布式文件存储系统Minio】2024.12保姆级教程
  • 解决ssh和git秘钥认证失败问题
  • AI安全的挑战:如何让人工智能变得更加可信
  • 腾讯通RTX升级迁移攻略,兼容Linux内核国产系统及移动端
  • 用css实现瀑布流布局
  • FortiAl为擎重塑网络与安全运营未来
  • 优化租赁小程序提升服务效率与用户体验的策略与实践
  • 基于Python的医院预约挂号与诊断系统
  • Spring Boot教程之四十:使用 Jasypt 加密 Spring Boot 项目中的密码
  • Design Compiler:两种工作模式(线负载模式和拓扑模式)
  • 窦明—环境和教育对人的影响具象化
  • 41.1 预聚合提速实战项目之需求分析和架构设计
  • 洛谷P2814 家谱(c嘎嘎)
  • 时空信息平台-API安全措施-下篇:登录鉴权【访问受限】您的请求已被该站点的安全策略拦截。
  • 找不到vcruntime140.dll文件,无法继续执行如何修复?共有7种方法
  • 【PCIe 总线及设备入门学习专栏 4.5 -- PCIe Message and PCIe MSI】
  • Docker搭建MySQL
  • #C01L11P02. C01.L11.while循环.while循环和for循环的区别
  • 利用deepspeed在Trainer下面微调大模型
  • 【spring】参数校验Validation
  • 基于PyQt5的UI界面开发——图像与视频的加载与显示
  • [python SQLAlchemy数据库操作入门]-16.CTE:简化你的复杂查询
  • 多分类的损失函数