4.Lua面向对象概念
2015-06-18 19:08
447 查看
Lua面向对象概念
Lua面向对象概念表中的方法
复制表
伪构造
伪继承
伪重写
闭包
1.表中的方法
在Lua的表中,存储的值可以是一个方法。info = {} info.uid = function() print("9206") end info.uid()
2.复制表
这里,用一个遍历的方式将一个表格进行复制。info = {} info.uid = function() print("9206") end function cloneTable(table) local temp = {} for key, var in pairs(table) do temp[key] = var end return temp end local newInfo = cloneTable(info) newInfo.uid()
3.伪“构造”
先介绍两个Lua语法:..:表示字符串连接。
x:函数():默认把x传进函数里。
info = {} info.uid = function(newInfo) print("9206:"..newInfo.name) end function cloneTable(table) local temp = {} for key, var in pairs(table) do temp[key] = var end return temp end info.new = function (name) local self = {} self = cloneTable(info) self.name = name return self end local newInfo = info.new("CaMnter") newInfo:uid()
4.伪“继承”
info = {} info.uid = function(newInfo) print("9206:"..newInfo.name) end function cloneTable(table) local temp = {} for key, var in pairs(table) do temp[key] = var end return temp end info.new = function (name) local self = {} self = cloneTable(info) self.name = name return self end function extend(child,super) for key, var in pairs(super) do child[key] = var end end msg = {1,2,3} msg.new = function(name) local temp = info.new(name) extend(temp,msg) return temp end local m = msg.new("m-CaMnter") m:uid()
这里,先定义了一个
msg表格,然后以上述“构造函数”的方式写了一个
new构造函数,然后调用
info.new(name)构造函数将实例好的info对象传入自定义的
extend函数中进行值的复制,最后完成伪“继承”。
5.伪“重写”
跟上面的代码一样,就加了一个msg方法的重写。info = {} info.uid = function(newInfo) print("9206:"..newInfo.name) end function cloneTable(table) local temp = {} for key, var in pairs(table) do temp[key] = var end return temp end info.new = function (name) local self = {} self = cloneTable(info) self.name = name return self end function extend(child,super) for key, var in pairs(super) do child[key] = var end end msg = {1,2,3} msg.new = function(name) local temp = info.new(name) extend(temp,msg) return temp end msg.uid = function(self) print("msg uid:9206 "..self.name) end local m = msg.new("m-CaMnter") m.uid(m)
6.闭包
闭包,我的理解就是引用了局部变量的函数。这个被引用的变量将会被外部以这个函数为入口所调用。就相当于Java中的
private属性要设置
setter和
getter方法一样。
function info(name) local object = {} object.name = name object.getName = function() print(object.name) end return object end function message(name) local object = info(name) object.getName = function() print("message:"..object.name) end return object end local m = message("CaMnter") for key, var in pairs(m) do print(key,var) end print("********************************") m:getName()
这里,因为方法message中定义了一个info类型的局部变量
object,如果直接m.name调用,LDT会直接提示错误,这是就相当于写了
getter的方法getName函数来获取obejct。
相关文章推荐
- 3.Lua表和数组
- lua 获取指定目录下指定后缀文件名
- 我所理解lua 语言中的点、冒号与self
- 1.Lua 环境搭建
- lua文件读写
- Lua lib 加载分析
- Virtual View Synthesis Method and Self Evaluation Metrics for Free Viewpoint Television and 3D Video
- Lua 学习笔记四 CoronaSDK使用
- Lua之sethook学习
- Lua之pcall和xpcall之学习
- Lua如何设置局部变量值进行调试
- VC中出现error C2064: term does not evaluate to a function
- Lua5.3 注册表 _G _ENV
- lua元表
- Lua5.3 注册表 _G _ENV
- 该怎样理解 Lua 逻辑运算符 and 和 or 的设计?
- Lua for Windows 安装方法
- Lua与C——扩展Lua(四)
- OpenWrt Web 开发 LuCI框架 lua语言
- 转 Lua标准库: table函数, 数学函数, 字符串函数/格式化/配对,