Lua面向?qū)ο笾惡屠^承淺析
Lua中的table就是一種對(duì)象,但是如果直接使用仍然會(huì)存在大量的問(wèn)題,如下:
Account = {balance = 0}
function Account.withdraw(v)
Account.balance = Account.balance - v
end
--下面是測(cè)試調(diào)用函數(shù)
Account.withdraw(100.00)
在上面的withdraw函數(shù)內(nèi)部依賴全局變量Account,一旦發(fā)生改變,將會(huì)導(dǎo)致withdraw不能正常工作,如:
a = Account; Account = nil
a.withdraw(100.00) --將會(huì)導(dǎo)致訪問(wèn)空nil的錯(cuò)誤。
這種行為明顯違反了面向?qū)ο蠓庋b性和實(shí)例獨(dú)立性。要解決這一問(wèn)題,我們需要給withdraw函數(shù)再添加一個(gè)參數(shù)self,他等價(jià)于java/C++中的this,如下:
function Account.withdraw(self,v)
self.balance = self.balance - v
end
--下面是基于修改后代碼的調(diào)用:
a1 = Account; Account = nil
a1.withdraw(a1,100.00) --正常工作。
針對(duì)上述問(wèn)題,lua提供了一種更為便利的語(yǔ)法,即將點(diǎn)(.)替換為冒號(hào)(:),這樣可以在定義和調(diào)用函數(shù)時(shí)隱藏參數(shù)。如:
function Account:withdraw(v)
self.balance = self.balance - v
end
--調(diào)用代碼可改為:
a:withdraw(100.00)
1、類:
lua中再語(yǔ)言上并沒(méi)有提供面向?qū)ο蟮闹С?,因此想?shí)現(xiàn)該功能,我們只能通過(guò)table來(lái)模擬,如下:
--這里的lovenumber是一個(gè)公有成員變量
Father={ lovenumber=0}
--new可以視為構(gòu)造函數(shù)
function Father:new(p)
p=p or {} --如果參數(shù)中沒(méi)有提供table,則創(chuàng)建一個(gè)空table
--將新對(duì)象實(shí)例的元表指向Father,這樣就可以以Father為模板了
setmetatable(p,self)
--將Father的__index字段指向自己,以便新對(duì)象在找不到指定的key時(shí)可以被重定向,即訪問(wèn)Father擁有的key
self.__index=self
return p
end
function Father:toString()
print("I love my son!")
end
--Loving被視為公有成員函數(shù)
function Father:Loving(v)
self.lovenumber=self.lovenumber+v --這里的self表示實(shí)例對(duì)象本身
return self.lovenumber
end
f1=Father:new{name="jianjian"}
f2=Father:new{name="baba",}
print(f1:Loving(100))
print(f2:Loving(200))
--輸出答案
--100
--200
2、繼承
繼承也是面向?qū)ο笾幸粋€(gè)非常重要的概念,在lua中我們也可以像模擬類那樣來(lái)實(shí)現(xiàn)繼承機(jī)制。
Father={ lovenumber=0}
function Father:new(p)
p=p or {}
--將新對(duì)象實(shí)例的元表指向Father,這樣就可以以Father為模板了
setmetatable(p,self)
--將Father的__index字段指向自己,以便新對(duì)象在找不到指定的key時(shí)可以被重定向,即訪問(wèn)Father擁有的key
self.__index=self
return p
end
function Father:toString()
print("I love my son!")
end
function Father:Loving(v)
self.lovenumber=self.lovenumber+v
return self.lovenumber
end
--下面派生出Father的一個(gè)子類,此時(shí)的Son仍為Father的一個(gè)對(duì)象實(shí)例
Son=Father:new()
--重寫(xiě)Father中的toString方法,以實(shí)現(xiàn)自定義功能
function Son:toString()
print("I love myself!")
end
--在執(zhí)行下面的new方法時(shí),table s的元表已經(jīng)是Son了,而不是Father
s=Son:new()
print(s:toString()) --先在子類Son中找到該方法
print(s:Loving(50)) --子類中無(wú)該方法,則調(diào)用父類中該方法
--輸出答案
--I love myself!
--50
相關(guān)文章
Lua之協(xié)同程序coroutine代碼實(shí)例
這篇文章主要介紹了Lua之協(xié)同程序coroutine代碼實(shí)例,本文給出的代碼示例較為復(fù)雜,需要對(duì)Lua協(xié)同程序有一定的了解方能看懂,需要的朋友可以參考下2015-04-04
lua獲取未來(lái)某時(shí)間點(diǎn)的時(shí)間戳解決方案
這篇文章主要介紹了lua獲取未來(lái)某時(shí)間點(diǎn)的時(shí)間戳解決方案,需要的朋友可以參考下2014-12-12
Lua中變相實(shí)現(xiàn)continue跳出循環(huán)
這篇文章主要介紹了Lua中變相實(shí)現(xiàn)continue跳出循環(huán),Lua中是沒(méi)有continue的,本文使用一個(gè)小技巧實(shí)現(xiàn)了跟continue一樣的效果,需要的朋友可以參考下2014-12-12
Lua中類的實(shí)現(xiàn)原理探討(Lua中實(shí)現(xiàn)類的方法)
這篇文章主要介紹了Lua中類的實(shí)現(xiàn)原理探討(Lua中實(shí)現(xiàn)類的方法),本文同時(shí)講解了metatable、元方法等內(nèi)容,需要的朋友可以參考下2014-10-10
Openresty服務(wù)器使用lua腳本寫(xiě)的Hello World簡(jiǎn)單實(shí)例
這篇文章主要介紹了Openresty服務(wù)器使用lua腳本寫(xiě)的Hello World簡(jiǎn)單實(shí)例,OpenResty (也稱為 ngx_openresty)是一個(gè)全功能的 Web 應(yīng)用服務(wù)器。它打包了標(biāo)準(zhǔn)的 Nginx 核心,很多的常用的第三方模塊,以及它們的大多數(shù)依賴項(xiàng),需要的朋友可以參考下2015-04-04

