Lua中的table就是一種對(duì)象,但是如果直接使用仍然會(huì)存在大量的問(wèn)題,如下:
復(fù)制代碼 代碼如下:
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不能正常工作,如:
復(fù)制代碼 代碼如下:
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,如下:
復(fù)制代碼 代碼如下:
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ù)。如:
復(fù)制代碼 代碼如下:
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)模擬,如下:
復(fù)制代碼 代碼如下:
--這里的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ī)制。
復(fù)制代碼 代碼如下:
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()
--重寫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
您可能感興趣的文章:- Lua面向?qū)ο笾惡屠^承
- Lua實(shí)現(xiàn)類繼承