Lua 语言 15 分钟快速入门(3)

-- 1. Dog看上去像一个类;其实它完全是一个table。
-- 2. 函数tablename:fn(...) 与函数tablename.fn(self, ...) 是一样的
--    冒号(:)只是添加了self作为第一个参数。
--    下面的第7和第8条说明了self变量是如何得到其值的。
-- 3. newObj是类Dog的一个实例。
-- 4. self为初始化的类实例。通常self = Dog,不过继承关系可以改变这个。
--    如果把newObj的元表和__index都设置为self,
--    newObj就可以得到self的函数。
-- 5. 记住:setmetatable返回其第一个参数。
-- 6. 冒号(:)在第2条是工作的,不过这里我们期望
--    self是一个实例,而不是类
-- 7. 与Dog.new(Dog)类似,所以 self = Dog in new()。
-- 8. 与mrDog.makeSound(mrDog)一样; self = mrDog。

----------------------------------------------------

-- 继承的例子:

LoudDog = Dog:new()                          -- 1.

function LoudDog:makeSound()
  s = self.sound .. ' '                      -- 2.
  print(s .. s .. s)
end

seymour = LoudDog:new()                      -- 3.
seymour:makeSound()  -- 'woof woof woof'      -- 4.

-- 1. LoudDog获得Dog的方法和变量列表。
-- 2. 通过new(),self有一个'sound'的key from new(),参见第3条。
-- 3. 与LoudDog.new(LoudDog)一样,并且被转换成
--    Dog.new(LoudDog),因为LoudDog没有'new' 的key,
--    不过在它的元表可以看到 __index = Dog。
--    结果: seymour的元表是LoudDog,并且
--    LoudDog.__index = LoudDog。所以有seymour.key
--    = seymour.key, LoudDog.key, Dog.key, 要看
--    针对给定的key哪一个table排在前面。
-- 4. 在LoudDog可以找到'makeSound'的key;这与
--    LoudDog.makeSound(seymour)一样。

-- 如果需要,子类也可以有new(),与基类的类似:
function LoudDog:new()
  newObj = {}
  -- 初始化newObj
  self.__index = self
  return setmetatable(newObj, self)
end


----------------------------------------------------
-- 4. 模块
----------------------------------------------------


--[[ 我把这部分给注释了,这样脚本剩下的部分就可以运行了

-- 假设文件mod.lua的内容是:
local M = {}

local function sayMyName()
  print('Hrunkner')
end

function M.sayHello()
  print('Why hello there')
  sayMyName()
end

return M

-- 另一个文件也可以使用mod.lua的函数:
local mod = require('mod')  -- 运行文件mod.lua.

-- require是包含模块的标准做法。
-- require等价于:    (针对没有被缓存的情况;参加后面的内容)
local mod = (function ()
  <contents of mod.lua>
end)()
-- mod.lua就好像一个函数体,所以mod.lua的局部变量对外是不可见的。

-- 下面的代码是工作的,因为在mod.lua中mod = M:
mod.sayHello()  -- Says hello to Hrunkner.

-- 这是错误的;sayMyName只在mod.lua中存在:
mod.sayMyName()  -- 错误

-- require返回的值会被缓存,所以一个文件只会被运行一次,
-- 即使它被require了多次。

-- 假设mod2.lua包含代码"print('Hi!')"。
local a = require('mod2')  -- 打印Hi!
local b = require('mod2')  -- 不再打印; a=b.

-- dofile与require类似,只是不做缓存:
dofile('mod2')  --> Hi!
dofile('mod2')  --> Hi! (再次运行,与require不同)

-- loadfile加载一个lua文件,但是并不允许它。
f = loadfile('mod2')  -- Calling f() runs mod2.lua.

-- loadstring是loadfile的字符串版本。
g = loadstring('print(343)')  --返回一个函数。
g()  -- 打印343; 在此之前什么也不打印。

--]]

内容版权声明:除非注明,否则皆为本站原创文章。

转载注明出处:http://www.heiqu.com/8710e4f46aed9f47edcdbb4c730058f7.html