LUA: 数组中有大间隔的情况下的内存使用?
2017-4-13 22:52:12
收藏:0
阅读:71
评论:1
如果我这样做:
listofstuff = {}
listofstuff[5] = 'foo'
listofstuff[9000] = 'bar'
listofstuff[200000] = 'baz'
它使用的内存比这个多吗?
listofstuff = {}
listofstuff[0] = 'foo'
listofstuff[1] = 'bar'
listofstuff[2] = 'baz'
如果是,第一个例子是否创建了198998个空/未使用的表数组值,但仍需要占用内存来存储结构?
点赞
评论区的留言会收到邮件通知哦~
推荐文章
- Lua 虚拟机加密load(string.dump(function)) 后执行失败问题如何解决
- 我想创建一个 Nginx 规则,禁止访问
- 如何将两个不同的lua文件合成一个 东西有点长 大佬请耐心看完 我是小白研究几天了都没搞定
- 如何在roblox studio中1:1导入真实世界的地形?
- 求解,lua_resume的第二次调用继续执行协程问题。
- 【上海普陀区】内向猫网络招募【Skynet游戏框架Lua后端程序员】
- SF爱好求教:如何用lua实现游戏内调用数据库函数实现账号密码注册?
- Lua实现网站后台开发
- LUA错误显式返回,社区常见的规约是怎么样的
- lua5.3下载库失败
- 请问如何实现文本框内容和某个网页搜索框内容连接,并把网页输出来的结果反馈到另外一个文本框上
- lua lanes多线程使用
- 一个kv数据库
- openresty 有没有比较轻量的 docker 镜像
- 想问一下,有大佬用过luacurl吗
- 在Lua执行过程中使用Load函数出现问题
- 为什么 neovim 里没有显示一些特殊字符?
- Lua比较两个表的值(不考虑键的顺序)
- 有个lua简单的项目,外包,有意者加微信 liuheng600456详谈,最好在成都
- 如何在 Visual Studio 2022 中运行 Lua 代码?

是的,它会使用更多的内存(大约是原来的2倍),但不会存储成千上万/百万个空槽。
在内部,表格是哈希图。它们只会分配足够存储您存放的值所需的槽位(向上舍入到下一个二的幂)。这意味着
listofstuff = {} listofstuff[5] = 'foo' listofstuff[9000] = 'bar' listofstuff[200000] = 'baz'将创建一个表格存储大约包含四个槽位的内容(粗略的伪表示法)
{ -- 忽略不相关的元数据 -- (查看 Lua 代码(ltable.c/ltable.h)以获取完整细节) arraysize = 0, hashsize = 4, array = null, hash = { { num:5, str:"foo" }, { dummy, dummy }, { num:200000, str:"bar" }, { num:9000, str:"bar"}, }, }(这只是一个示例,顺序可能完全不同。)
另一个示例将会存储大约如下:
{ arraysize = 2, hashsize = 1, array = { str:"bar", str:"baz" }, hash = { { num:0, str:"foo" }, }, }如果您有一系列连续的整数键,则无需存储键(节省一半的内存),如果值存储为数组,则位置在该数组中的值就是键。
[就像 Lua 中的每个位置一样,数组从1开始。但是如果您的数组从0开始,这没有问题-额外的槽将与键一起存储在哈希中。如果没有很好的理由从0开始,请从1开始。但是,如果您必须调整算法或公式才能那样做,请从0开始。]