关于Lua Module机制分析
关于Lua Module机制分析是本文要介绍的内容,主要是来了解并学习Lua Module机制,具体内容来看本文详解。Lua中的模块(module)机制有点类似于C语言的动态库,可以将一些公共的代码放在模块中,以API的形式提供给Lua应用脚本使用。使用模块或许还可以做成像Android的Application Frameworks,建立一种新的应用程序编程模型,只是猜想。
模块最简单的使用方式:
view plaincopy to clipboardprint?require “os” os.clock() require “os” os.clock()
table
Lua语言共有8中数据类型,其中table(表)类型实现了“关联数组(associative array)”。table中可以保存各种数据类型。和table关联的metatable,它定义了表的操作的一些行为,比如: 使用+操作时,会去查找metatable的属性__add,有的话执行。
function
function是Lua中8中基本类型之一,和其它类型一样可以作为值传递。和function有关联的表是环境表(environment),可以认为是function的执行环境。可以通过setfenv()和getfenv()来设置和获取函数的环境表。函数中对于全局的操作,比如:定义全局变量等;就是在这个表中进行的。多个函数可以共享一个表
require
当使用require加载一个模块时,实际上做了如下的事情:
在表package.loaded中查找模块是否存在,有的话就返回该值。可以使用如下函数输出表中的内容
view plaincopy to clipboardprint?function walkTable(t) for k,v in pairs(t) do print("+++",k,v,"+++") end end function walkTable(t) for k,v in pairs(t) do print("+++",k,v,"+++") end end
package.loaded中的内容如下,其中包含了一些默认加载的库和全局表_G
view plaincopy to clipboardprint?+++ string , table: 003B82B0 +++ +++ debug , table: 003B9300 +++ +++ package , table: 003B5C30 +++ +++ _G , table: 003B2E10 +++ +++ io , table: 003B7320 +++ +++ os , table: 003B7988 +++ +++ table , table: 003B51E0 +++ +++ math , table: 003B8728 +++ +++ coroutine , table: 003B59D8 +++ +++ string , table: 003B82B0 +++ +++ debug , table: 003B9300 +++ +++ package , table: 003B5C30 +++ +++ _G , table: 003B2E10 +++ +++ io , table: 003B7320 +++ +++ os , table: 003B7988 +++ +++ table , table: 003B51E0 +++ +++ math , table: 003B8728 +++ +++ coroutine , table: 003B59D8 +++
为模块查找加载器(loader),查询package.preload,通常为空
加载Lua文件使用loadfile函数。loadfile会将文件当作函数来加载,require会将模块名作为参数传给该函数。若有返回值则将返回值放入表package.loaded中。若没有则返回表package.loaded中的值。
module
当在模块文件中使用module函数的时候,如下所示;
view plaincopy to clipboardprint?module “mymodule” module “mymodule”
实际上等同于以下的语句:
view plaincopy to clipboardprint?local modname = “mymodule” – 定义模块名 local M = {} -- 定义用于返回的模块表 _G[modname] = M -- 将模块表加入到全局变量中 package.loaded[modname] = M -- 将模块表加入到package.loaded中,防止多次加载 setfenv(1,M) -- 将模块表设置为函数的环境表,这使得模块中的所有操作是以在模块表中的,这样定义函数就直接定义在模块表中 local modname = “mymodule” – 定义模块名 local M = {} -- 定义用于返回的模块表 _G[modname] = M -- 将模块表加入到全局变量中 package.loaded[modname] = M -- 将模块表加入到package.loaded中,防止多次加载 setfenv(1,M) -- 将模块表设置为函数的环境表,这使得模块中的所有操作是以在模块表中的,这样定义函数就直接定义在模块表中
通过module(),可以方便的编写模块中的内容。
测试环境
相关推荐
表格的现在还是较为常用的一种标签,但不是用来布局,常见处理、显示表格式数据。在HTML网页中,要想创建表格,就需要使用表格相关的标签。<table> <tr> <td>单元格内的文字</td> ...