# MemoryPool **Repository Path**: ZHU-WX/memory-pool ## Basic Information - **Project Name**: MemoryPool - **Description**: 高效智能内存分配中心 - **Primary Language**: Unknown - **License**: Not specified - **Default Branch**: master - **Homepage**: None - **GVP Project**: No ## Statistics - **Stars**: 0 - **Forks**: 0 - **Created**: 2025-12-28 - **Last Updated**: 2025-12-28 ## Categories & Tags **Categories**: Uncategorized **Tags**: None ## README # MemoryPool #### 介绍 ##### 所用技术: C/C++、数据结构(链表、哈希桶)、单例模式、多线程、TLS线程本地存储、互斥锁等。 ##### 项目简介: 基于google的一个开源项目-tcmalloc,实现一个多线程环境下的内存分配器,多个线程可以并发申请内存,并可以对内存进行合并,解决多线程下锁竞争问题、内存申请效率问题以及内存碎片问题。 ##### 功能实现: Thread Cache:哈希桶结构,用于小于256kb的内存申请,每个线程独享一个线程缓存,不需要加锁。 Central Cache:所有线程所共享,也是一个哈希桶结构,不同线程访问同一个桶时,需要加锁,Thread Cache按需从Central Cache中获取内存,如果Thread Cache中内存满足一定条件Central Cache也会回收Thread Cache中的内存,从而避免一个线程占用太多内存,减少内存碎片。 Page Cache:以页为单位进行分配和管理,Central Cache没有内存时从Page Cache申请一定数量的页,并切割为小内存挂到Central Cache哈希桶中,方便分配给Thread Cache,Page Cache也会回收Central Cache中满足条件的Span对象,并合并相邻的Span,合并出更大的页来缓解内存碎片问题。 性能测试: 内存池与malloc、free进行对比,比较多线程下申请释放相同大小内存,随机大小内存所需时间。 内存池的申请释放所需时间比malloc/free所需时间要短的多,内存池申请释放效率更高。 #### 软件架构 软件架构说明 #### 安装教程 1. xxxx 2. xxxx 3. xxxx #### 使用说明 1. xxxx 2. xxxx 3. xxxx #### 参与贡献 1. Fork 本仓库 2. 新建 Feat_xxx 分支 3. 提交代码 4. 新建 Pull Request #### 特技 1. 使用 Readme\_XXX.md 来支持不同的语言,例如 Readme\_en.md, Readme\_zh.md 2. Gitee 官方博客 [blog.gitee.com](https://blog.gitee.com) 3. 你可以 [https://gitee.com/explore](https://gitee.com/explore) 这个地址来了解 Gitee 上的优秀开源项目 4. [GVP](https://gitee.com/gvp) 全称是 Gitee 最有价值开源项目,是综合评定出的优秀开源项目 5. Gitee 官方提供的使用手册 [https://gitee.com/help](https://gitee.com/help) 6. Gitee 封面人物是一档用来展示 Gitee 会员风采的栏目 [https://gitee.com/gitee-stars/](https://gitee.com/gitee-stars/)