lua 游戏架构 之 TablePool`对象池

定义一个名 `TablePool` class,用于管理一个对象池。对象池是一种用于优化内存使用的技术,通过重用对象而不是频繁地创建和销毁对象,从而减少内存分配和垃圾回收的开销。

设计思路

  1. **初始化**:
  • `initialize` 方法初始化对象池,接受三个参数:`capacity`(池子的容量,即最多可以缓存多少个对象)、`newFunc`(创建新对象的函数)和 `rlsFunc`(释放对象的函数)。

  • 根据提供的 `capacity`,预先创建一定数量的对象并存储在队列 `_ts` 中。

  1. **获取对象**:
  • `getObj` 方法从对象池中获取一个对象。如果池子中有对象,则从队列的头部取出一个对象;如果池子为空且提供了 `newFunc`,则调用 `newFunc` 创建一个新的对象;否则返回一个空表。
  1. **释放对象**:
  • `releaseObj` 方法将一个对象放回池子中。如果提供了 `rlsFunc`,则在放回之前调用 `rlsFunc` 释放对象。如果对象已经在队列的尾部,则记录错误信息,因为这意味着对象被重复释放。
  1. **销毁对象池**:
  • `release` 方法用于销毁对象池,将所有成员变量置为 `nil`。

用途

对象池通常用于需要频繁创建和销毁对象的场景,例如游戏开发中的游戏对象、数据库连接池等。通过使用对象池,可以显著减少内存分配和垃圾回收的开销,提高程序的性能。

注意事项

  1. **对象重用**:对象池中的对象在被取出后,应确保在释放之前不会被修改,以避免数据不一致的问题。

  2. **错误处理**:在 `releaseObj` 方法中,如果尝试释放的对象已经在队列的尾部,会记录错误信息。这通常意味着对象被重复释放,需要检查代码逻辑。

  3. **线程安全**:如果对象池在多线程环境中使用,需要确保线程安全,避免多个线程同时访问和修改对象池。

Lua 复制代码
---@class TablePool
local TablePool = SimpleClassUtil:class()

---@param capacity number
---@param newFunc fun() : table
---@param rlsFunc fun(t : table)  void
function TablePool:initialize(capacity, newFunc, rlsFunc)
    local cap = capacity or 4
    ---@type Queue
    self._ts = Queue:new()
    self._newFunc = newFunc -- or _defaultNew
    self._rlsFunc = rlsFunc
    if newFunc then
        for i = 1, cap do
            self._ts:pushBack(newFunc())
        end
    else
        for i = 1, cap do
            self._ts:pushBack({})
        end
    end
end

---@return table @从池子里获取的table
function TablePool:getObj()
    if self._ts then
        local cnt = self._ts:size()
        if cnt <= 0 then
            if self._newFunc then
                return self._newFunc()
            else
                return {}
            end
        else
            return self._ts:popFront()
        end
    end
end

---@param item table @一定是Get返回的table
function TablePool:releaseObj(item)
    if self._ts then
        if self._rlsFunc then
            self._rlsFunc(item)
        end

        if self._ts:peekBack() == item then
            Logger.error("Try Release item to TablePool Failed! You try Release same item twice.", item)
        else
            self._ts:pushBack(item)
        end
    end
end

---@overload fun()
function TablePool:release(obsolete)
    if obsolete then
        Logger.error("TablePool:release has Changed Name to TablePool:releaseObj!")
        self:releaseObj(obsolete)
        return
    end

    self._newFunc = nil
    self._rlsFunc = nil
    self._ts = nil
end

return TablePool
相关推荐
阿坤带你走近大数据2 小时前
数仓架构的设计思路、模型选择依据、落地难点及解决方案的介绍
架构·管理·数仓·业务与技术融合
ftpeak2 小时前
Mooncake:以 KVCache 为中心的分离式 LLM 服务架构
人工智能·ai·架构·ai编程·ai开发
Agent手记5 小时前
制造业生产流程自动化,Agent需要具备哪些能力?深度拆解2026工业级智能体落地范式与核心架构
大数据·人工智能·ai·架构·自动化
Yunzenn6 小时前
深度分析字节最新研究cola-DLM 第 07 章:推理流水线逐行拆解 —— 从 prompt 到生成文本
人工智能·驱动开发·深度学习·chatgpt·架构·prompt·github
颖火虫盟主7 小时前
Linux 系统分层架构:从硬件通电到 systemd 进程管理
linux·运维·架构
ฅ ฅBonnie8 小时前
Hermes 与 Cloud Code/OpenClaw 架构对比分析及部署实践
人工智能·ai·架构·ai编程
实在智能RPA9 小时前
实在Agent针对金融行业Agent灾备与高可用是如何进行设计的?深度拆解金融级智能体的架构安全与连续性保障
人工智能·安全·ai·金融·架构
zhangfeng11339 小时前
主流推理模型架构的协议对比表格,和专利坑 专利埋雷
人工智能·语言模型·自然语言处理·架构·开源·开源协议
这是谁的博客?9 小时前
LangChain 框架深度解析:从 LCEL 到 Agent 架构的核心原理
ai·架构·langchain·llm·agent·架构设计
Championship.23.249 小时前
Linux 3.0 中断机制深度解析:从传统PIC到现代中断架构的转折点
linux·运维·架构·中断