Updated performance.
This commit is contained in:
parent
bd5ed55ebd
commit
da4dbf89c2
@ -89,7 +89,7 @@ assert(Immutable{a=1,b=2,c=3} == Immutable{a=1,b=2,c=3})
|
||||
```
|
||||
|
||||
## Performance
|
||||
This library is pretty dang fast, but it's still slower than native Lua tables. Based on my benchmarks, in Lua 5.3.3, creating a new 2-member immutable tables takes about 2.83 nanoseconds (compared to 0.47 for a lua table), but creating a new 2-member immutable table that matches one already in memory takes about the same time as making a lua table (0.46 nanoseconds). Accessing members takes about 0.171 nanoseconds on the immutable table, compared to about 0.016 nanoseconds on a lua table. And accessing class members takes about 0.16 nanoseconds on an immutable table, compared to about 0.038 nanoseconds accessing the `__index` of a lua table's metatable. The numbers on LuaJIT are a bit hard to suss out because LuaJIT does a lot of optimizations on table access, but roughly speaking, immutable tables are faster when running on LuaJIT, but there is a greater discrepancy
|
||||
This library is pretty dang fast, but it's still slower than native Lua tables. Based on my local testing, immutable tables add a couple nanoseconds to things in the worst case scenario. In LuaJIT, there is a bigger performance discrepancy because immutable tables are about the same, but regular tables are much faster in LuaJIT. Your mileage may vary, but I'd say that immutable tables will probably never be a performance bottleneck for your program, especially if you were previously already using a constructor function and metatables. In some cases, immutable tables may also help reduce your program's memory footprint (if your program has many duplicate objects in memory) and may even improve speed (e.g. if your program uses a lot of deep equality checks). Don't trust this paragraph though! If in doubt, profile your code!
|
||||
|
||||
## Implementation details
|
||||
Under the hood, immutable tables are implemented in C as a userdata (that stores a hash value) with a metatable. That metatable has a weak-keyed mapping from hash -> userdata -> associated data. Immutable tables *are* garbage collected, so if you no longer have any references to the userdata, the userdata will get garbage collected, which will result in the entry being removed from the metatable's mapping. When new instances are created, a hash value is computed, and all the data in the associated hash bucket is scanned to look for duplicates. If a match is found, that existing instance is returned, otherwise a new one is created and added to the hash bucket. The following lua pseudocode approximates the C implementation's behavior:
|
||||
|
Loading…
Reference in New Issue
Block a user