0基础lua学习(十二)Lua 模块与包

Lua 模块与包

模块相似于一个封装库,从 Lua 5.1 开始,Lua 加入了标准的模块管理机制,能够把一些公用的代码放在一个文件里,以 API 接口的形式在其余地方调用,有利于代码的重用和下降代码耦合度。web

Lua 的模块是由变量、函数等已知元素组成的 table,所以建立一个模块很简单,就是建立一个 table,而后把须要导出的常量、函数放入其中,最后返回这个 table 就行。如下为建立自定义模块 module.lua,文件代码格式以下:数组

-- 文件名为 module.lua
-- 定义一个名为 module 的模块
module = {}

-- 定义一个常量
module.constant = "这是一个常量"

-- 定义一个函数
function module.func1()
    io.write("这是一个公有函数!\n")
end

local function func2()
    print("这是一个私有函数!")
end

function module.func3()
    func2()
end

return module

由上可知,模块的结构就是一个 table 的结构,所以能够像操做调用 table 里的元素那样来操做调用模块里的常量或函数。
上面的 func2 声明为程序块的局部变量,即表示一个私有函数,所以是不能从外部访问模块里的这个私有函数,必须经过模块里的公有函数来调用.ruby

require 函数svg

Lua提供了一个名为require的函数用来加载模块。要加载一个模块,只须要简单地调用就能够了。例如:
require(“<模块名>”)
或者
require “<模块名>”
执行 require 后会返回一个由模块常量或函数组成的 table,而且还会定义一个包含该 table 的全局变量。函数

-- test_module.lua 文件
-- module 模块为上文提到到 module.lua
require("module")

print(module.constant)

module.func3()

以上代码执行结果为:
这是一个常量
这是一个私有函数!ui

或者给加载的模块定义一个别名变量,方便调用:
– test_module2.lua 文件
– module 模块为上文提到到 module.lua
– 别名变量 m
local m = require(“module”)lua

print(m.constant)spa

m.func3()
以上代码执行结果为:
这是一个常量
这是一个私有函数!code

加载机制

咱们要研究lua的加载机制其实也是很简单的xml

require("haha");

咱们加载一个不存在的模块

报错:
no field package.preload[‘haha’]
no file ‘.\haha.lua’
no file ‘C:\Program Files (x86)\Lua\5.1\lua\haha.lua’
no file ‘C:\Program Files (x86)\Lua\5.1\lua\haha\init.lua’
no file ‘C:\Program Files (x86)\Lua\5.1\haha.lua’
no file ‘C:\Program Files (x86)\Lua\5.1\haha\init.lua’
no file ‘C:\Program Files (x86)\Lua\5.1\lua\haha.luac’
no file ‘.\haha.dll’
no file ‘.\haha51.dll’
no file ‘C:\Program Files (x86)\Lua\5.1\haha.dll’
no file ‘C:\Program Files (x86)\Lua\5.1\haha51.dll’
no file ‘C:\Program Files (x86)\Lua\5.1\clibs\haha.dll’
no file ‘C:\Program Files (x86)\Lua\5.1\clibs\haha51.dll’
no file ‘C:\Program Files (x86)\Lua\5.1\loadall.dll’
no file ‘C:\Program Files (x86)\Lua\5.1\clibs\loadall.dll’

print("require查找的路径")
print(package.path)
print("------------------")
print("require找不到的,就来c路径下找")
print(package.cpath)

--当找到了这个文件之后,若是这个文件是一个Lua文件,
--它就经过loadfile来加载该文件;
--若是找到的是一个C程序库,就经过loadlib来加载?
--loadfile和loadlib都只是加载了代码,
--并无运行它们,为了运行代码,
--require会以模块名做为参数来调用这些代码
相关文章
相关标签/搜索