在函数上定义属性与在函数.prototype上定义属性
2020-10-22 20:18:53
收藏:0
阅读:113
评论:1
tl;dr 如果你熟悉javascript的工作原理,请跳到“问题”部分。
我来自javascript,在那里我们使用原型链来定义我们的“class”方法,例如:
function MyClass(){
return this
}
MyClass.prototype.method = function(){
// do stuff
}
MyClass.directPropFunction = function(){
// do direct stuff
}
MyClass.method() // 不起作用
MyClass.directPropFunction() // 起作用
new MyClass() // 从所述“class”实例化对象
new MyClass().method() // 现在它起作用了!
new MyClass().directPropFunction() // 但现在不再起作用了。
换句话说,在函数上定义直接属性可以被认为是“静态”方法,而在原型上定义属性可以被认为是常规方法。所有这些都建立在我们通过使用函数作为对象的构造函数来“伪造”类然后访问它们并使用它们的原型链来完成魔术事情的事实上。
一个重要的事情需要注意的是,甚至在原型上声明的.method也不是为对象的每个实例创建的。LUA是否有扩展函数对象的“适当”方式?
问题:
我在LUA中搞了一些事情,遇到了这个问题:我不知道它的内部工作原理,有什么区别和做事的首选方式是什么?另外,我不确定LUA是否具有整个“伪造”类,但我可能不会使用它,因此以下显示的哪种方法是“正确”的?
function Foo()
-- do stuff
end
Foo.method = function()
-- do stuff
end
Foo.prototype.protoMethod = function()
-- do stuff
end
我想要达到的是以下内容:
function doSomething()
-- does something, duh
-- return uniqueID
end
doSomething.revert = function(uniqueID)
-- reverts stuff
end
然后我将能够同时执行以下操作:
local a = doSomething()
doSomething.revert(a)
那么正确的方法是什么?
点赞
评论区的留言会收到邮件通知哦~
推荐文章
- Lua 虚拟机加密load(string.dump(function)) 后执行失败问题如何解决
- 我想创建一个 Nginx 规则,禁止访问
- 如何将两个不同的lua文件合成一个 东西有点长 大佬请耐心看完 我是小白研究几天了都没搞定
- 如何在roblox studio中1:1导入真实世界的地形?
- 求解,lua_resume的第二次调用继续执行协程问题。
- 【上海普陀区】内向猫网络招募【Skynet游戏框架Lua后端程序员】
- SF爱好求教:如何用lua实现游戏内调用数据库函数实现账号密码注册?
- Lua实现网站后台开发
- LUA错误显式返回,社区常见的规约是怎么样的
- lua5.3下载库失败
- 请问如何实现文本框内容和某个网页搜索框内容连接,并把网页输出来的结果反馈到另外一个文本框上
- lua lanes多线程使用
- 一个kv数据库
- openresty 有没有比较轻量的 docker 镜像
- 想问一下,有大佬用过luacurl吗
- 在Lua执行过程中使用Load函数出现问题
- 为什么 neovim 里没有显示一些特殊字符?
- Lua比较两个表的值(不考虑键的顺序)
- 有个lua简单的项目,外包,有意者加微信 liuheng600456详谈,最好在成都
- 如何在 Visual Studio 2022 中运行 Lua 代码?

考虑以下练习:
local function reversible (func) local states = {} states [func] = states [func] or {} return function (...) local result = func (...) states [func] [result] = {...} return result end, function (result) return unpack (states [func] [result]) end end local square, root = reversible (function (a) return a ^ 2 end) local initial = -2 local squared = square (initial) local reversed = root (squared) io.write ('initial = ' .. tostring (initial) .. ', squared = ' .. tostring (squared) .. ', reversed = ' .. tostring (reversed) .. '\n')当然,在这个例子中,被恢复的“状态”仅由函数参数组成;因此,
func必须是纯函数。假定原始函数只返回一个值(如果返回多个值,则states应该用func的结果的哈希值打包到一个表中进行索引)。与 JavaScript 不同,在 Lua 中函数没有属性,对象没有原型。然而,Lua 表具有元表(metatables)。
此外,如果表的元表具有
__call字段,则可以通过表字段来模拟函数属性,当表被像函数一样调用时使用。下面的例子实现了伪属性revert并且允许多个返回值的原始函数:local function hash (array) return table.concat (array, ',') end local function reversible (func) local states = {} states [func] = states [func] or {} local wrapped = { revert = function (...) return unpack (states [func] [hash {...}]) end } setmetatable (wrapped, { __call = function (tbl, ...) local results = {func (...)} states [func] [hash (results)] = {...} return unpack (results) end }) return wrapped end local square = reversible (function (a) return a ^ 2 end) print ('square (-2)', square (-2)) print ('square.revert (4)', square.revert (4))