为什么需要在Lua字符串缓冲区中保留创建的大字符串
2021-9-1 15:58:59
收藏:0
阅读:153
评论:1
我最近阅读了《Programming in Lua》的11.6节“String Buffers”部分。作者提供了一种类似汉诺塔的算法,用于在逐行读取文本文件时将创建的大字符串保存在堆栈底部。
这种方法为什么需要在字符串缓冲区数据结构中使用?这是一种加快内存操作的黑科技吗?
我不明白的是,为什么作者要将小字符串连接成一个大字符串?
例如,为什么不只是使用这个作为“addString”函数?
function addString (stack, s)
table.insert(stack, s) -- 将's'压入堆栈中
end
原文链接 https://stackoverflow.com/questions/69014494
点赞
评论区的留言会收到邮件通知哦~
推荐文章
- 如何在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 代码?
- addEventListener 返回 nil Lua
- Lua中获取用户配置主目录的跨平台方法
- 如何编写 Lua 模式将字符串(嵌套数组)转换为真正的数组?
例如,为什么不仅使用此函数作为addString函数?
因为你仍需要一种方法来连接你插入的所有字符串。你可能会使用
table.concat
来完成这个任务,但是所呈现的算法展示了如何在不使用table.concat
函数的情况下以合理的性能方式执行此操作。你可以简单地使用table.insert
,但是示例显示了描述如何提高性能的操作(即使相同的算法已经实现并可供您使用)。[更新以回答在评论中的问题不同]
让我们看看从GC的角度来看有什么不同之处。
local t = 0 function addString (stack, s) table.insert(stack, s) for i=#(stack)-1, 1, -1 do if string.len(stack[i]) > string.len(stack[i+1]) then break end print(#(stack[i+1]), #(stack[i])) t = t + #(stack[i+1]) + #(stack[i]) stack[i] = stack[i] .. table.remove(stack) end end local s = {""} local tbl = {"1", "2", "3", "4", "5", "6", "7", "8", "9", "0", "a", "b", "c", "d", "e", "f"} for _, line in ipairs(tbl) do addString(s, line) end while #s > 1 do local i = #s-1 print(#(s[i+1]), #(s[i])) t = t + #(s[i+1]) + #(s[i]) s[i] = s[i] .. table.remove(s) end print(t, s[1]) local s = "" local t = 0 for _, line in ipairs(tbl) do print(#s, #line) t = t + #s + #line s = s .. line end print(t, s)
如果我们运行建议的算法和naive算法,如上所示,我们可以看到第一个算法报告了65个释放字符串的长度,第二个算法报告了136个。这就是内存重新分配的节省之处(尽管在两种情况下操作数量相同)。
你可以在最简单的情况下看到它:1,1,1,1。第一个算法将它们组合为1 + 1,1 + 1,然后2 + 2,结果字符串为4,释放的(中间的)字符串为1,1,1,1,2,2,总共为8。
naive算法将执行1+1,2+1,3+1,结果字符串相同为4,但是释放的字符串为1,1,1,1,2,3,总共为9。
连接的字符串越多,优势越大。