【Lua】面向对象编程(二)
多重继承:
module(...,package.seeall) local function search(k,plist)
for i=,#plist do
local v=plist[i][k]
if v then
return v
end
end
end --多重继承
function createClass(...)
local c={}
local parents={...}
setmetatable(c,{
__index=function(t,k)
return search(k,parents)
end
}) c.__index=c --c作为其实例的元表 c.new=function(self,o)
o=o or {}
setmetatable(o,c)
return o
end return c
end
注:
Lua实现多重继承的关键在于,__index元字段为一个函数
--多重继承
NamedAccount=MMultiInherit.createClass(MNamed.Named,MAccount.Account)
account=NamedAccount:new()
account:setName("Paul")
print(account:getName())
print(account:getBalance()
注:
如上创建一个继承自Named类和Account类的新类NamedAccount,需要调用createClass,创建NamedAccount对象account,Lua在account中无法找到setName时,会查找account元表中的__index字段,该字段为NamedAccount,由于NamedAccount无法提供setName字段,因此Lua查找NamedAccount元表中的__index字段,是一个函数,Lua就调用它,该函数现在Named中查找setName字段,最终在Named中找到一个非nil的值。
类的封装:
Lua实现类的封装(私密性)的做法是,通过两个table来表示一个对象,一个table用于保存对象的状态,另一个用于对象的操作,或者称为“接口”,对象本身通过第二个table来访问(即通过气接口的方法来访问)。
module(...,package.seeall) --[[
Lua 私密性实现,通过两个table表示一个对象,一个table用于保存对象的状态;另一个用于对象的操作,或者称为“接口”,
对象本身通过第二个table来访问,即通过其接口的方法来访问。
]]
function newAccount(initialBalance) --保存对象的状态
local self={
balance=initialBalance,
limit=1000.0
} local extra=function()
if self.balance > self.limit then
return self.balance *0.1
else
return
end
end local withdraw=function(money)
self.balance=self.balance-money
end local deposit=function(money)
self.balance=self.balance+money
end local getBalance=function()
return self.balance+extra()
end --返回对象的“接口”
return {
withdraw=withdraw,
deposit=deposit,
getBalance=getBalance
}
end
注:
如上所示,函数先创建了一个table,用于保存对象的内部状态,并将其存储在局部变量self中,然后再创建对象的方法,最后函数创建并返回一个供外部使用的对象,其中将方法名与真正的方法实现匹配起来。
这种设计给予了存储在self table中的所有东西完全的私密性,只能通过newAccount中创建的函数访问self table,另外可以定义私有的方法,他们类似于共有的方法,但是不放入接口中,如extra函数,即为私有方法。
【Lua】面向对象编程(二)的更多相关文章
- Python进阶之面向对象编程(二)
Python面向对象编程(二) .note-content {font-family: "Helvetica Neue",Arial,"Hiragino Sans GB& ...
- Lua面向对象之二:类继承
1.类继承 ①代码 Sharp = { } --① 父类 function Sharp:new() local new_sharp = { } self.__index = self --②,self ...
- Lua面向对象编程
Lua中的table就是一种对象,看以下一段简单的代码: , b = } , b = } local tb3 = tb1 if tb1 == tb2 then print("tb1 == t ...
- python之路---面向对象编程(二)
类的继承 1.在python3中,只有新式类,新式类的继承方式为:广度优先.而python2中,经典类的继承方式为:深度优先.那么我们来看看深度优先和广度优先的区别吧 如下图,为类之间的继承关系.B, ...
- lua面向对象编程 《lua程序设计》 16章 笔记
Lua中的table就是一种对象,即它拥有状态.拥有独立于其值的标识(self).table与对象一样具有独立于创建者和创建地的征集周期 什么叫对象拥有独立的生命周期? Account = {bala ...
- Java面向对象编程(二)
上一篇博文里总结了面向对象三大特性在Java中的体现.如今谈一谈Java中的抽象类,接口,内部类等特性. 一. 抽象类 public abstract class Shape { public int ...
- php面向对象编程(二)
现在我们来了解一下面向对象的一个封装性的问题 封装性:在我的理解里面 可以理解为一个u盘 我们使用u盘的接口与电脑进行数据之间的交互 但是我们不能看到里面的结构 这个特性我们可以称为封装性 好处:利用 ...
- lua 面向对象编程类机制实现
lua no class It is a prototype based language. 在此语言中没有class关键字来创建类. 现代ES6, 已经添加class类. prototype bas ...
- Python之路【第五篇续】:面向对象编程二
aaarticlea/png;base64,iVBORw0KGgoAAAANSUhEUgAABgQAAALaCAIAAABxja8cAAAgAElEQVR4nOzd6X9Tdd74/+uv+f5uzF
- Python入门之面向对象编程(二)python类的详解
本文通过创建几个类来覆盖python中类的基础知识,主要有如下几个类 Animal :各种属性.方法以及属性的修改 Dog :将方法转化为属性并操作的方法 Cat :私人属性讲解,方法的继承与覆盖 T ...
随机推荐
- CSS3给页面打标签
我们经常会在页面的左上角或者右上角看到类似如图所示的标签,比如页面的链接(最常使用)等,下面我们就实现一个简单的标签 实现步骤是先做一个水平长条,使用CSS3的transform来实现旋转,如果是在左 ...
- ubuntu压缩
.tar解包:tar xvf FileName.tar打包:tar cvf FileName.tar DirName(注:tar是打包,不是压缩!)-------------------------- ...
- day01<计算机基础知识&Java语言基础>
计算机基础知识(计算机概述) 计算机基础知识(软件开发和计算机语言概述) 计算机基础知识(人机交互) 计算机基础知识(键盘功能键和快捷键) 计算机基础知识(如何打开DOS控制台) 计算机基础知识(常见 ...
- Redis(六)-- SpringMVC整合Redis
一.pom.xml <project xmlns="http://maven.apache.org/POM/4.0.0" xmlns:xsi="http://www ...
- /etc/docker/key.json
/etc/docker/key.json 描述信息: This is the dockerd key for TLS connections.in web format, that docker us ...
- JAVA Comparator 接口排序用法
java的比较器有两类,分别是Comparable接口和Comparator接口. 在为对象数组进行排序时,比较器的作用非常明显,首先来讲解Comparable接口. 让需要进行排序的对象实现Comp ...
- java三方---->dom4j解析xml数据
Dom4j是一个易用的.开源的库,用于XML,XPath和XSLT.它应用于Java平台,采用了Java集合框架并完全支持DOM,SAX和JAXP.今天我们就开始Dom4j的学习. Dom4j的使用 ...
- SpringBoot SpringApplication底层源码分析与自动装配
目录 抛出问题 @SpringBootApplication注解剖析 SpringApplication类剖析 第一步:配置SpringBoot Bean来源 第二步 :自动推断SpringBoot的 ...
- 【数组】—冒泡排序&&选择排序---【巷子】
/* 什么是冒泡排序:从头到尾比较相邻的两个数的大小,如果符合条件则进行比较 [注]:从小到大进行排序 假设有一个数组 var arr = [9,8,7,6,5,4]; 我们想要进行这个数组进行排序那 ...
- mysql 修改配置文件性能优化
vim /etc/my.cnf 原配置文件 [mysqld] datadir=/var/lib/mysql socket=/var/lib/mysql/mysql.sock user=mysql # ...