当一个函数内嵌套另一个函数的时候,内部的函数可以访问外部函数的局部变量,这种特征叫做词法定界。
lua当中函数是一个值,他可以存在变量中,可以作为其他函数的参数,可以作为返回值
function test()
local i=0
return function()
i++
...
end
end
//这里的函数作为返回值,这里的i也叫外部局部变量,lua中称为upvalue
//这里的内部函数可以访问外部函数test的函数局部变量i
闭包:如果一个函数内部含义一个函数的定义,被包含的函数称为内部函数,包含的函数称为外部函数,这个内部函数能够访问外部函数里面定义的变量,这个变量称为外部局部变量。如果函数作为返回值,则这整个部分被称为闭包。
闭包组成:外部函数+外部函数创建的upvalue+被返回的内部函数(闭包函数)
function test()
local i=0
return function()//定义一个函数并返回,这个函数当前没有被调用
i+=1
return i
end
end
c1=test()
c2=test()//c1,c2是两个不同的闭包
//闭包中的upvalue各自独立互不影响,调用一次test()就会产生一个新的闭包
print(c1()) -->1
print(c1()) -->2//重复调用时每一个调用都会记住上一次调用后的值,就是说i=1了已经
print(c2()) -->1//闭包不同所以upvalue不同
print(c2()) -->2
闭包在迭代器中的运用:迭代器需要保留上一次调用的状态,刚好可以使用闭包的机制来实现,返回闭包的函数在这时称为迭代器 创建迭代器:
function list_iter(t)
local i=0
local n=table.getn(t)
return function()
i=i+1
if i
关注
打赏
最近更新
- 深拷贝和浅拷贝的区别(重点)
- 【Vue】走进Vue框架世界
- 【云服务器】项目部署—搭建网站—vue电商后台管理系统
- 【React介绍】 一文带你深入React
- 【React】React组件实例的三大属性之state,props,refs(你学废了吗)
- 【脚手架VueCLI】从零开始,创建一个VUE项目
- 【React】深入理解React组件生命周期----图文详解(含代码)
- 【React】DOM的Diffing算法是什么?以及DOM中key的作用----经典面试题
- 【React】1_使用React脚手架创建项目步骤--------详解(含项目结构说明)
- 【React】2_如何使用react脚手架写一个简单的页面?