lua 脚本之高级篇 (面向对象的完全支持),有性能问题。
----------------------------------------------------------
--面向对象核心库
----------------------------------------------------------
----------------------------------------------------------
--base object
object = {}
function object:getName()
return "unknow"
end
function object:resetHashCode()
self.__hashcode = nil
self:getHashCode()
end
function object:getHashCode()
self.__hashcode = self.__hashcode or (os.time() + math.random())
return self.__hashcode
end
----------------------------------------------
-- create interface helper
function createInterface(object,name,func)
warning(object[name] == nil,"Interface exists,create fail" .. name)
end
function callInsterface(object,name,...)
local func = object[name]
return func(object,...)
end
function callmethod(object,name,...)
local func = object[name]
return func(object,...)
end
function implementInterface(object,name,func)
object[name] = func
end
function createAbstract(object,name,func)
object[name] = function(self)
warning(false,"not implement Abstract " .. name)
return nil
end
end
function createVirtualFunction(object,name,func)
implementInterface(object,name,func)
end
function override(object,name,func)
implementInterface(object,name,func)
end
function sealed(object)
object.__sealed = true
end
----------------------------------------------
--oop helpers
local function addctor(class)
assert(class,"class is nil value")
if class.ctor == nil then
class.ctor = function(self) end
end
end
function registerFun_getInstance(cls)
-- warning(cls.getInstance == false,"cls has function:getInstacnce")
cls.__instance = nil;
cls.getInstance =function()
if cls.__instance == nil then
assert(cls.new and type(cls.new)== "function","not found ctor function :new");
cls.__instance = cls:new()
return cls.__instance
end
return cls.__instance
end
end
---向对象中添加临时数据
function setTempVariable(object,key,value)
assert(key,"key is a nil value")
assert(value~=nil,"value is a nil value")
object.__tempData = object.__tempData or {}
object.__tempData["__"..key] = value
end
---查找对象中保存的临时数据
function getTempVariable(object,key)
assert(object,"object is a nil value")
assert(key,"key is a nil value")
if object.__tempData == nil then return nil end
return object.__tempData["__"..key]
end
function callSupper(instance,supperName,name,cls,...)
if instance ~= nil then
if instance.supper == nil then return end
if instance.supper[supperName] ~=nil then
for key, var in pairs( instance.supper[supperName]) do
if key == name then
local fun = var
local returnValue,e = pcall(fun,cls or instance,...)
assert(e==nil,e)
return returnValue,true
end
end
else
for key, var in pairs(instance.supper) do
if type(var) == "table" and key~="__index" and key ~= "__child" then
local returnValue,result = callSupper(var,supperName,name,instance,...)
if result == true then return returnValue,true end
end
end
end
if instance.__child ~=nil then
local returnValue,result = callSupper(instance.__child,supperName,name,cls,...)
if result == false and instance.__child.__child then
returnValue,result = callSupper(instance.__child.__child,supperName,name,cls,...)
end
return returnValue,true
end
end
return nil,false
end
---调用基类中的函数
function callSupperA(instance,supperName,name,...)
return callSupper(instance,supperName,name,instance,...)
end
local function copyAllSupper(class,base)
if base ~= nil and class ~= nil and base.supper ~= nil then
class.supper = class.supper or {}
for key, var in pairs(base.supper) do
if class.supper[key] == nil then
class.supper[key] = var
end
end
end
end
--继承帮助函数
--ext:扩展类,
--base:基类
--supper name
---------------------------------------------
--@param #table ext 当前类的定义
--@param #table base 当前类的要继承的类,一般也为table
--@param #string suppername 当前继承的基类的别名
--@return #table 一个新的对旬的实列
function inheritanceA(ext,base,suppername)
-- assert(ext,"not set ext object.")
-- assert(base,"not set base object.")
-- assert(base.__sealed == nil,"基类设置为了禁止继承.")
if base.__sealed ~= nil then
assert(base.__sealed == nil,"基类设置为了禁止继承.")
return
end
--metatable copy
local function setmetatableA(tag,source)
for k,v in pairs(source) do
if tag[k] == nil then
if type(v) == "table" and k ~= "__index" and k~= "__child" then
tag[k] = {}
setmetatableA (tag[k],v)
tag[k].__index = tag[k]
else
tag[k] = v
end
end
end
return tag
end
ext = setmetatableA(ext,base)
ext.__index = ext
--添加自己的构造函数
if ext.new == nil then
function ext.new ( self )
local instance = {}
setmetatableA(instance,self)
instance.__index = instance
instance:ctor()
instance:resetHashCode()
return instance,ext.supper
end
addctor(ext)
end
ext.supper = ext.supper or {}
setmetatableA(ext.supper,base)
ext.supper.__child = ext
ext.supper.__index = ext.supper;
---添加基类的默认构造函数
if ext.supper and ext.supper.new == nil then
---此逻辑的意义不大
ext.supper.new = ext.supper.new or function ( self )
local instance = {}
setmetatableA(instance,self)
instance:resetHashCode()
return ext.supper,ext.supper or {}
end
addctor(ext.supper)
end
if suppername ~= nil and type(ext.supper[suppername])~= "function" then
ext.supper[suppername] = ext.supper[suppername] or {}
setmetatableA(ext.supper[suppername],base)
ext.supper[suppername].__index = ext.supper[suppername]
end
ext.__index = ext;
---注册单列接口
registerFun_getInstance(ext)
return ext,ext.supper
end
---继承对象实例
--@param #table ext 当前对象的实例
--@param #table base 基类的实例
function inheritance(ext,base)
-- assert(false,"调用本函数只能通过supper来访问,如果多少继承,只有最后一次继承的会生效")
return inheritanceA(ext or {},base,"__supper")
end
---继承自model 文件
--@param #table ext 当前对象的实例
--@param #string mname 当前要继承的模块对象
function inheritanceM(ext,mname)
local obj = require (mname)
assert(obj~=nil,"load mode error,mode name:"..mname)
return inheritanceA(ext,obj,mname)
end
return object
lua 脚本之高级篇 (面向对象的完全支持),有性能问题。的更多相关文章
- Javascript高级篇-面向对象的特性
一.创建对象 1.1初始化器 var any={ name:"some", age:10, action:function(){ alert(this.name+":&q ...
- 要想用活Redis,Lua脚本是绕不过去的坎
前言 Redis 当中提供了许多重要的高级特性,比如发布与订阅,Lua 脚本等.Redis 当中也提供了自增的原子命令,但是假如我们需要同时执行好几个命令的同时又想让这些命令保持原子性,该怎么办呢?这 ...
- Lua学习高级篇
Lua学习高级篇 之前已经说了很多,我目前的观点还是那样,在嵌入式脚本中,Lua是最优秀.最高效的,如果您有不同的观点,欢迎指正并讨论,切勿吐槽.这个系列完全来自于<Programming in ...
- 第二十三篇:在SOUI中使用LUA脚本开发界面
像写网页一样做客户端界面可能是很多客户端开发的理想. 做好一个可以实现和用户交互的动态网页应该包含两个部分:使用html做网页的布局,使用脚本如vbscript,javascript做用户交互的逻辑. ...
- 第五篇:python高级之面向对象高级
python高级之面向对象高级 python高级之面向对象高级 本节内容 成员修饰符 特殊成员 类与对象 异常处理 反射/自省 单例模式 1.成员修饰符 python的类中只有私有成员和公有成员两 ...
- 【COCOS2DX-LUA 脚本开发之一】在Cocos2dX游戏中使用Lua脚本进行游戏开发(基础篇)并介绍脚本在游戏中详细用途!
[COCOS2DX-LUA 脚本开发之一]在Cocos2dX游戏中使用Lua脚本进行游戏开发(基础篇)并介绍脚本在游戏中详细用途! 分类: [Cocos2dx Lua 脚本开发 ] 2012-04-1 ...
- Unity3D热更新之LuaFramework篇[07]--怎么让unity对象绑定Lua脚本
前言 在上一篇文章 Unity3D热更新之LuaFramework篇[06]--Lua中是怎么实现脚本生命周期的 中,我分析了由LuaBehaviour来实现lua脚本生命周期的方法. 但在实际使用中 ...
- Unity3D热更新之LuaFramework篇[05]--Lua脚本调用c#以及如何在Lua中使用Dotween
在上一篇文章 Unity3D热更新之LuaFramework篇[04]--自定义UI监听方法 中,我对LuaBehaviour脚本进行了扩展,添加了两个新的UI监听方法,也提到最好能单写一个脚本处理此 ...
- Redis分布式锁—SETNX+Lua脚本实现篇
前言 平时的工作中,由于生产环境中的项目是需要部署在多台服务器中的,所以经常会面临解决分布式场景下数据一致性的问题,那么就需要引入分布式锁来解决这一问题. 针对分布式锁的实现,目前比较常用的就如下几种 ...
随机推荐
- ListView使用--文章集锦
详解ListView加载网络图片的优化,让你轻松掌握! ListView具有多种item布局--实现微信对话列 关注公众号,分享干货,讨论技术
- Linux中短横线(-)小记
在Linux中短横线(-)可以表示输出流,具体用法如下. 搭配cat cat - 如果指定cat的文件为-,表示从标准输入读取(和直接使用cat,好像没什么区别) 搭配| echo 123 | cat ...
- Django-models,继承AbstractUser类
1.UserInfo类继承了Django模型自带的User类,需要导入AbstractUser 2.然后在settings.py中配置
- python3 json、logging、sys模块
json模块 import json dic = {'name':'egon','age':32} # ------------------------------>序列化 f = open(' ...
- vi错误terminal too wide解决方法
vi错误terminal too wide解决方法 http://blog.sina.com.cn/s/blog_3f68daa00100vcsh.html
- php7安装及和php5的共存
http://blog.csdn.net/liuxinmingcode/article/details/50319145 http://www.jb51.net/article/109228.htm ...
- 关于C++编译的程序无法在新一台电脑上运行总结
最近在调用一个SDK调试一个主板的DPIO. 可是编译好的程序在开发电脑上运行没问题,到了新主板建立的电脑系统上就出问题. 总结了下要注意一下几方面. 1:程序本身要没有问题.至少在开发电脑系统环境下 ...
- import详解
试想一下 在工作中今年在一个项目中可能会导入某一个目录下的模块文件,那这个时候怎么样才能让Python解释器能够找到该模块进行调用呢? - 将这个模块拷贝一份到当前使用目录下. 这种方式让模块太冗余 ...
- 《Java编程思想》笔记 第十三章 字符串
1.String对象不可变 String对象不可变,只读.任何指向它的引用都不能改变它的内容.改变String内容意味着创建了一个新的String对象. String 对象作为方法参数时都会复制一份引 ...
- docker从零开始网络(三) overly(覆盖)网络
使用overly网络 该overlay网络驱动程序会创建多个docker进程主机之间的分布式网络.该网络位于(覆盖)特定于主机的网络之上,允许连接到它的容器(包括群集服务容器)安全地进行通信.Dock ...