🔗 Lua string concatenation considered not harmful
A user in the Lua mailing list recently asked the following question:
yield( splits[i-1][1]..word[i+1]..word[i]..splits[i+2][2] )
I tried table.concat and string.format, but both perform worst. This was
counter-intuitive to me, because Lua string concat generates copies of
intermediate strings. However, seems that for short strings and small number
of concatenated strings, string __concat performs better than string.format
or table.concat. Does anyone know if my observation is true?
The “folk wisdom” about copies of intermediate strings in Lua is often mis-stated, I think.
("aa"):upper() .. ("bb"):upper() .. ("cc"):upper() .. ("dd"):upper()
It translates to a single concatenation bytecode in both Lua and LuaJIT, so it produces the following strings in memory over the course of its execution:
"aa" "bb" "cc" "dd" "AA" "BB" "CC" "DD" "AABBCCDD"
This, on the other hand, does generate intermediate strings:
local s = "" for _, w in ipairs({"aa", "bb", "cc", "dd"}) s = s .. w:upper() end
It produces
"" "aa" "bb" "cc" "dd" "AA" "BB" "CC" "DD" "AABB" "AABBCC" "AABBCCDD"
Notice the little pyramid at the end. This pattern is the one that people tell to avoid when they talk about “intermediate strings”. For a loop like that, one should do instead:
local t = {} for _, w in ipairs({"aa", "bb", "cc", "dd"}) table.insert(s, w:upper()) end local s = table.concat(t)
That will produce:
"aa" "bb" "cc" "dd" "AA" "BB" "CC" "DD" "AABBCCDD"
plus an extra table. Of course this is an oversimplified example for illustration purposes, but often the loop is long and the naive approach above can produce a huge pyramid of intermediate strings.
Over the years, the sensible advice was somehow distorted into some “all string concatenation is evil” cargo-cult, but that is not true, especially for short sequences of concatenations in an expression. Using a..b..c will usually be cheaper and produce less garbage than either string.format(”%s%s%s”, a, b, c) or table.concat({a, b, c}).
🔗 LuaRocks 3.0.0beta1
I am extremely happy to announce LuaRocks 3.0.0beta1, the almost-finished package for the new major release of LuaRocks, the Lua package manager.
First of all: “Why beta1?” — the code itself is release-candidate
quality, but I decided to call this one beta1 and not rc1 because the
Windows package is not ready yet, and I wanted to get some early
feedback on the Unix build while I complete the final touches of the
Windows package.This is NOT going to be a long-or-endless beta cycle: if no major
showstoppers are reported, the final 3.0.0 release, including Unix and
Windows packages, is expected to arrive in one week. But please, if
you want to help out with LuaRocks, give this beta1 a try and report
any findings!
Yes, it’s finally here! After a way-too-long gestation period, LuaRocks 3 is about ready to see the light of day. And it includes a lot of new stuff:
- New rockspec format
- New commands, including `luarocks init` for per-project workflows
- New flags, including `–lua-dir` and `–lua-version` for using
- multiple Lua installs with a single LuaRocks
- New build system, gearing towards a new distribution model
- General improvements, including namespaces
- User-visible changes, including some breaking changes
- Internal changes
All of the above are detailed here:
https://github.com/luarocks/luarocks/blob/master/CHANGELOG.md
I’ll try to write up more documentation between now and the final release. Feedback is wanted regarding what needs to be documented/explained! And help updating the wiki is especially welcome.
And without further ado, the tarball for Unix is here:
https://luarocks.github.io/luarocks/releases/luarocks-3.0.0beta1.tar.gz
This release contains new code by Thijs Schreijer, George Roman, Peter Melnichenko, Kim Alvefur, Alec Larson, Evgeny Shulgin, Michal Cichra, Daniel Hahler, and myself.
Very special thanks to my employer Kong, for sponsoring my work on LuaRocks over the last year and making this release possible. Thanks also to my colleagues Aapo Talvensaari and Enrique García Cota for helping out with some last-minute testing.
In the name of everyone in the LuaRocks development team, thank you for the continued amazing support that Lua community has been giving LuaRocks over the years: keep on rockin’!
Cheers!!!
Follow
🐘 Mastodon ▪ RSS (English), RSS (português), RSS (todos / all)
Last 10 entries
- Frustrating Software
- What every programmer should know about what every programmer should know
- A degradação da web em tempos de IA não é acidental
- There are two very different things called "package managers"
- Last day at Kong
- A Special Hand
- How to change the nmtui background color
- Receita de Best Pancakes
- That time I almost added Tetris to htop
- Receita de Orange Chicken