匿名函数 vs 非匿名函数 Lua

我正在学习Lua并了解匿名函数的概念。这很有趣,但我想知道它相对于非匿名函数还提供了什么额外的优势。

假设我有以下的函数:

function(a,b) return (a+b) end

此函数是匿名的。如果我有以下函数:

function add(a,b) return (a+b) end

则此函数是非匿名的。后者更好,因为我可以在任何地方调用它,且了解我的函数正在执行什么操作。那么,匿名函数的优点是什么呢?我有什么遗漏了吗?

原文链接 https://stackoverflow.com/questions/8142026

点赞
stackoverflow用户221509
stackoverflow用户221509

说实话,在 Lua 中并没有所谓的“命名函数”。所有的函数实际上都是匿名的,但可以存储在变量中(这些变量有名称)。

所谓的“命名函数”语法 function add(a,b) return a+b end 实际上是一种语法糖,相当于 add = function(a,b) return a+b end

函数通常用作事件处理程序和一些库不知道或无法确定的决策,其中最著名的例子是 table.sort() - 使用你的函数,你可以指定排序顺序:

people = {{name="John", age=20}, {name="Ann", age=25}}
table.sort(people, function (a,b) return a.name < b.name end)

重点是你很可能不需要之后再用到这个函数。当然,你也可以将函数保存到(可能是局部的)变量中并使用它:

local nameComparator = function (a,b) return a.name < b.name end
table.sort(people, nameComparator)

有关更多信息,请参阅 PiL 中的函数部分

2011-11-15 19:47:26
stackoverflow用户275115
stackoverflow用户275115

第二个例子等价于

add = function(a,b) return a+b end

所以从某种程度上说,你一直在使用匿名函数,只是在一些微不足道的情况下。

但在其他情况下,匿名函数可以变得更加有用。例如,使用函数来变异其他函数(函数式编程的灵魂)。

function make_version_with_n_args (func, n)
    if n == 1 then
        return function (x) return x end
    else
        return function (x, ...)
            return func (x, make_version_with_n_args (func, n-1)(...))
        end
    end
end

add_four = make_version_with_n_args (function (a, b) return a+b end, 4)

print (add_four(3, 3, 3, 3))

add_sizes = {}
for i = 1, 5 do
    add_sizes[i] = make_version_with_n_args(function (a, b) return a+b end, i)
end

func_args = {}
for i = 1, 5 do
    func_args[#func_args+1] = 2
    print (add_sizes[i](unpack(func_args)))
end

function make_general_version (func)
    return function (...)
        local args = {...}
        local result = args[#args]
        for i = #args-1,1,-1 do
            result = func(args[i], result)
        end
        return result
    end
end

general_add = make_general_version (function (a, b) return a+b end)

print (general_add(4, 4, 4, 4))

基本上,如果你愿意,你可以为每个函数创建一个名称,但在你需要大量使用一次性函数的情况下,_不这样做更加方便_。

2011-11-15 19:52:54