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

Lua垃圾回收机制

Lua垃圾回收机制

在 Lua 中,一共只有8种数据类型,分别为 nil 、boolean 、userdata 、number 、string 、 table 、 function 、 userdata 和 thread 。其中,只有 string table function thread 四种是以引用方式共享,是需要被 GC 管理回收的对象。
Lua采用了标记清除式(Mark and Sweep)GC算法,算法简述:
标记:每一次执行GC前,从根节点开始遍历每一个相关节点,进行标记
清除:标记完成后,遍历对象链表,然后对需要执行清除标记的对象,进行清除

使用三色法:白,灰,黑,作为对象的三种状态
新白:可以回收的对象;新创建的对象,初始状态是新白,但不会被清除
旧白:可以回收的对象;lua只会清除旧白,GC后,会更新新白
灰色:等待回收的对象:该对象已被GC访问过,但该对象引用的其它对象还未标记
黑色:不可回收的对象

清理流程

将root集合引用到的对象从White设置成Gray,并放到Gray集合中;while(Gray集合不为空,并且没有超过本次计算量的上限)
{从Gray集合中移除一个对象O,并将O设置成Black状态;for(O中每一个引用到的对象O1) {if(O1在White状态) {将O1从White设置成Gray,并放到到Gray集合中;}}
}
for(任意一个对象O){if(O在White状态)销毁对象O;else将O设置成White状态;
}
http://www.lryc.cn/news/435309.html

相关文章:

  • Java学习路线:详细指引
  • 商家转账到零钱如何开通-微信支付
  • 自研商家如何快速接入电商平台订单数据?
  • Win10下借助CMake编译OpenMVS
  • 04_定时器与数码管基础
  • Python 数学建模——方差分析
  • 计算机视觉中,什么是上下文信息(contextual information)?
  • YOLOv5改进 | 模块缝合 | C3 融合RVB + EMA注意力机制【二次融合】
  • mysql 更改默认端口号 新增用户密码 赋予权限
  • 吐血整理nacos 作为springcloud的配置中心和注册中心
  • 【秋招笔试】9.09阿里国际秋招(已改编)-三语言题解
  • sql语句在sqlserver中能查询出结果,但是代码中查不出来
  • 【机器学习】决策树与随机森林:模型对比与应用案例分析
  • Apache SeaTunnel基础介绍
  • 阿里旗下土耳其电商Trendyol计划进军欧洲市场
  • IBM中国研发裁员与AIGC浪潮下的中国IT产业新篇章:挑战、机遇与未来展望
  • 基于Python的影视推荐平台的设计与实现--附源码79147
  • Baumer工业相机堡盟工业相机如何通过BGAPISDK使用短曝光功能(曝光可设置1微秒)(C语言)
  • Ubuntu 安装PostgreSQL
  • sqlalchemy FastAPI 前端实现数据库增删改查
  • QQueue调用dequeue闪退解决方法
  • CSP-J算法基础 计数排序
  • Java泛型类型解析
  • EasyExcel 学习之 导出 “类型及精度问题”
  • 从视频中每隔10帧截取一帧并保存为图片
  • 防火墙、firewalld指令、更改yum源为阿里云的yum源及常见问题
  • 5G Multicast/Broadcast Services(MBS) (二) Multicast
  • 【计算机方向】中科院二区潜力刊!最快14天accept,还是非OA ,不能错过!
  • 合适做项目交付的物联网平台:ThingsKit
  • python绘制3D瀑布图