gpt4 book ai didi

optimization - 一次将值声明为本地值比每次都声明为本地值要慢

转载 作者:行者123 更新时间:2023-12-03 15:58:38 25 4
gpt4 key购买 nike

这段代码怎么可能:

local t
for n = 0, 255 do
t = math.random(0, 255)
...
end

居然比这个还慢?
for n = 0, 255 do
local t = math.random(0, 255)
...
end

由于我正在访问 t不止一次在 ...部分,我想知道,做 for循环有自己的局部变量集吗?如果是,从当前块访问局部变量是否比从外部块访问局部变量更快?

最佳答案

通常,尽可能将变量声明为局部变量。是的,for循环有自己的作用域。这是更好的编码风格,而且,如本例所示,通常更优化。

让我们看看这两段代码生成了什么指令,用luac -l
第一段:

main <t.lua:0,0> (13 instructions at 00000000005e8260)
0+ params, 8 slots, 1 upvalue, 5 locals, 5 constants, 0 functions
1 [1] LOADNIL 0 0
2 [2] LOADK 1 -1 ; 0
3 [2] LOADK 2 -2 ; 255
4 [2] LOADK 3 -3 ; 1
5 [2] FORPREP 1 6 ; to 12
6 [3] GETTABUP 5 0 -4 ; _ENV "math"
7 [3] GETTABLE 5 5 -5 ; "random"
8 [3] LOADK 6 -1 ; 0
9 [3] LOADK 7 -2 ; 255
10 [3] CALL 5 3 2
11 [3] MOVE 0 5
12 [2] FORLOOP 1 -7 ; to 6
13 [4] RETURN 0 1

第二件:
main <t.lua:0,0> (11 instructions at 0000000000538260)
0+ params, 7 slots, 1 upvalue, 5 locals, 5 constants, 0 functions
1 [1] LOADK 0 -1 ; 0
2 [1] LOADK 1 -2 ; 255
3 [1] LOADK 2 -3 ; 1
4 [1] FORPREP 0 5 ; to 10
5 [2] GETTABUP 4 0 -4 ; _ENV "math"
6 [2] GETTABLE 4 4 -5 ; "random"
7 [2] LOADK 5 -1 ; 0
8 [2] LOADK 6 -2 ; 255
9 [2] CALL 4 3 2
10 [1] FORLOOP 0 -6 ; to 5
11 [3] RETURN 0 1

如你看到的。第一段有两个额外的说明。其中之一在循环内:
        11      [3]     MOVE            0 5

这样做是将结果移动到寄存器 5 (其结果为 math.random ,到寄存器 0 (这是变量 t 所在的位置)。这就回答了你的问题。

关于optimization - 一次将值声明为本地值比每次都声明为本地值要慢,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/37327948/

25 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com