当我将unpack()称为lua的函数参数时会发生什么?

时间:2016-05-22 08:34:05

标签: lua arguments

以下是我看到的内容:

> function test(...)
>>  for i, v in ipairs({...}) do
>>    print(v)
>>  end
>>end

-- This is expected
> test(unpack({1,2}))
1
2
-- When I mix unpack and regular arguments
-- What happened to 2?
> test(unpack({1,2}), 3)
1
3
-- What happened to 3?
> test(unpack({}), 3)

-- When I put regular args before unpack, everything is fine:
> test(1, unpack({2, 3}))
1
2
3

当我将解压缩的参数与常规args混合时,结果很奇怪。你能解释一下幕后发生的事情吗?

2 个答案:

答案 0 :(得分:4)

参见Lua手册中的解释:

  

如果表达式用作列表的最后一个(或唯一的)元素   表达式,然后没有进行调整(除非表达式是   括在括号中)。在所有其他情况下,Lua调整了   结果列表到一个元素,要么丢弃除了的所有值   第一个

你得到了这个。 Unpack()返回多个值,返回的元素列表被调整为1个元素,除非它是test()参数中的最后一个表达式。

答案 1 :(得分:3)

我会引用Lua的参考文献:

  

函数调用和vararg表达式都可能导致多个   值。如果表达式用作语句(仅适用于   函数调用(参见§2.4.6)),然后将其返回列表调整为零   元素,因此丢弃所有返回的值。如果表达式是   用作表达式列表的最后一个(或唯一的)元素   没有进行调整(除非呼叫括在括号中)。在   在所有其他上下文中,Lua将结果列表调整为一个元素,   丢弃除第一个以外的所有值。

如您所见,您的解包调用减少为一个返回值,因为它既不是您传递给测试的表达式列表中的最后一个也是唯一一个表达式:

test(unpack({1,2}), 3)

在另一种情况下,答案很简单:

test(unpack({}), 3)

传递给test的第一个值是nil。因此,for i, v in ipairs({...}) do end只会nil返回unpack({})

,因此nil将无法执行任何操作
  

ipairs(t)

     

返回三个值(迭代器函数,表t和0)   那个建筑

 for i,v in ipairs(t) do body end
     

将迭代键值对(1,t [1]),(2,t [2]),...,直到第一个零值。