lua 面向对象编程类机制实现
lua no class
It is a prototype based language。
在此语言中没有class关键字来创建类。
现代ES6, 已经添加class类。 prototype based 语言没啥优势。
lua 如何构建class机制?
https://github.com/fanqingsong/oopclass.lua
提供lua的 Object Oriented Programing Class 实现: 比其他实现更加轻量 https://github.com/Yonaba/Lua-Class-System 特色功能: 1、 虚类声明 2、 单例声明 3、 类冰封, 一旦冰封后, 类的属性不能被改变。
code -- oopclass.lua
local _M = {} -- Instantiates a class local function _instantiate(class, ...) -- 抽象类不能实例化 if rawget(class, "__abstract") then error("asbtract class cannot be instantiated.") end -- 单例模式,如果实例已经生成,则直接返回 if rawget(class, "__singleton") then -- _G[class]值为本class的实例 if _G[class] then return _G[class] end end local inst = setmetatable({__class=class}, {__index=class}) if inst.__init__ then inst:__init__(...) end --单例模式,如果实例未生成,则将实例记录到类中 if rawget(class, "__singleton") then if not _G[class] then _G[class] = inst -- 对类对象增加实例获取接口 class.getInstance = function ( self ) return _G[class] end -- 销毁单例,为后续建立新单例准备 class.destroyInstance = function ( self ) _G[class] = nil end end end return inst end -- LUA类构造函数 function _M.class(base) local metatable = { __call = _instantiate, } -- 先查原型表,然后查父亲类 metatable.__index=function(t, k) local v = t.__prototype[k] if v then return v end local parent = t.__parent if parent then return parent[k] end return nil end -- 缓存类的field metatable.__newindex=function (t,k,v) rawset(t.__prototype, k, v) end local _class = {} -- __parent 属性缓存父类 _class.__parent = base or {} -- 存储此类的所有field _class.__prototype = {} -- 在class对象中记录 metatable ,以便重载 metatable.__index _class.__metatable = metatable -- 将类冷冻,不允许新建删除修改 _class.freeze = function ( self ) local mt = getmetatable(self) mt.__newindex=function (t,k,v) error("class is frozen, cannot revise") end end return setmetatable(_class, metatable) end --- Test whether the given object is an instance of the given class. -- @param object Object instance -- @param class Class object to test against -- @return Boolean indicating whether the object is an instance -- @see class -- @see clone function _M.instanceof(object, class) local objClass = object.__class if not objClass then return false end while objClass do if objClass == class then return true end objClass = objClass.__parent end return false end return _M
使用
local oopclass = require("oopclass") local class = oopclass.class local instanceof = oopclass.instanceof local superTab = class() superTab.test = function ( self ) print("superTab test") end superTab:freeze() superTab.test2 = function ( self ) print("superTab test2") end local tab = class(superTab) local tabObj = tab() tabObj:test() print( instanceof(tabObj, tab) ) print( instanceof(tabObj, superTab) )
出处:http://www.cnblogs.com/lightsong/
本文版权归作者和博客园共有,欢迎转载,但未经作者同意必须保留此段声明,且在文章页面明显位置给出原文连接。
【推荐】编程新体验,更懂你的AI,立即体验豆包MarsCode编程助手
【推荐】凌霞软件回馈社区,博客园 & 1Panel & Halo 联合会员上线
【推荐】抖音旗下AI助手豆包,你的智能百科全书,全免费不限次数
【推荐】轻量又高性能的 SSH 工具 IShell:AI 加持,快人一步
· 深入理解 Mybatis 分库分表执行原理
· 如何打造一个高并发系统?
· .NET Core GC压缩(compact_phase)底层原理浅谈
· 现代计算机视觉入门之:什么是图片特征编码
· .NET 9 new features-C#13新的锁类型和语义
· Spring AI + Ollama 实现 deepseek-r1 的API服务和调用
· 《HelloGitHub》第 106 期
· 数据库服务器 SQL Server 版本升级公告
· 深入理解Mybatis分库分表执行原理
· 使用 Dify + LLM 构建精确任务处理应用
2015-11-04 算法-朴素字符串匹配