lyh916

  博客园  :: 首页  :: 新随笔  :: 联系 :: 订阅 订阅  :: 管理
  201 随笔 :: 0 文章 :: 12 评论 :: 21万 阅读

参考链接:

https://blog.csdn.net/liu943367080/article/details/88951964

https://blog.csdn.net/MaximusZhou/article/details/44280109

 

一.定义

如果方法f1中存在方法f2,那么称f2为f1的内嵌方法,f1为f2的外包方法。外包和内嵌都具有传递性,即f2的内嵌必然是f1的内嵌,f1的外包必然是f2的外包

内嵌方法能访问外包方法中的局部变量,这些变量称为非局部变量(upvalue)

闭包由一个方法和该方法会访问到的upvalue组成。可以认为,在lua中一般定义的方法其实是闭包的一种特殊情况(无upvalue)

 

二.特性

1.upvalue的复制

如下,g1和g2有各自的upvalue,当参数n离开作用域时,闭包会为它分配内存空间并保存当前的值

复制代码
 1 function f1(n) --函数参数n也是局部变量
 2     local function f2()
 3         print(n)   --引用外部函数的局部变量
 4     end
 5     return f2
 6 end
 7 
 8 g1 = f1(2015)
 9 g1() -- 打印出2015
10 
11 g2 = f1(2016)
12 g2() -- 打印出2016
复制代码

 

2.upvalue的共享

如下,f1和f2共享upvalue,因为当lua发现这2个闭包的upvalue指向的是当前堆栈上的相同变量时,会只生成1份拷贝,然后让这2个闭包共享该拷贝,从而实现了闭包之间的通讯

复制代码
 1 function Create(n)
 2     local function foo1()
 3         print(n)
 4        end
 5        local function foo2()
 6         n = n + 10
 7        end
 8     return foo1,foo2
 9 end
10 
11 f1,f2 = Create(2015)
12 f1() -- 打印2015
13 
14 f2()
15 f1() -- 打印2025
16 
17 f2()
18 f1() -- 打印2035
复制代码

 

posted on   艰苦奋斗中  阅读(338)  评论(0编辑  收藏  举报
编辑推荐:
· .NET Core 中如何实现缓存的预热?
· 从 HTTP 原因短语缺失研究 HTTP/2 和 HTTP/3 的设计差异
· AI与.NET技术实操系列:向量存储与相似性搜索在 .NET 中的实现
· 基于Microsoft.Extensions.AI核心库实现RAG应用
· Linux系列:如何用heaptrack跟踪.NET程序的非托管内存泄露
阅读排行:
· TypeScript + Deepseek 打造卜卦网站:技术与玄学的结合
· Manus的开源复刻OpenManus初探
· AI 智能体引爆开源社区「GitHub 热点速览」
· 三行代码完成国际化适配,妙~啊~
· .NET Core 中如何实现缓存的预热?
点击右上角即可分享
微信分享提示