1.关于三目运算符的一些补充和纠正
前面没看仔细 a>b ? a: b 这个形式 似乎lua下并不存在。。。要了命
一般都是使用 a and b or c 的形式 但是这种形式存在一些问题
详细说了lua下的三目运算符的最终形式和为什么要这么写
完整三目运算符(a and {b} or {c})[1]
123
2 关于lua的两种调用类方法的区别
a==>类名
a:test() a.test()==》类名a下的类方法test()
function a:test()
print(self.name .. "test") end如果在类方法中的test()如果使用了当前类 比如self 那么在外面调用 这个类方法的时候
a:test()
a.test(a)--这种形式需要传递进当前的类名 不然会出错
3 Lua的面向对象编程相关
4 lua的文件操作处理和读写操作
lua的IO库常用函数的介绍(文件读写操作)
--读取指定路径文件全部内容 成功返回内容 读取失败返回nilfunction readfile(path) local file = io.open(path, "r")--找不到并不会自动创建 if file then local content = file:read("*a") io.close(file) return content end return nilend--把表元素的作为文件的一行覆盖写入到文件里面function writetabletofile(path,temptable) temptable=((type(temptable)=="table") and {temptable} or { {}})[1] --万一是没写入i第二个参数或者第二个参数不是表就给个空表 local tempstr="" local file --1.构建要写入的 而且为了避免表元素类型的差异 强制转化为字符串以防万一 for v,k in pairs(temptable) do tempstr=tempstr .. tostring(k) .. "\n" end --2.写入指定文件 if tostring(tempstr)~="" then file = io.open(path, "w")--w模式下如果文件不存在会自动创建 if file then file:write(tempstr) io.close(file) return else return nil end else return nil endend--读取指定路径文件全部内容到表中 成功返回表 读取失败返回nil 不过要注意 返回值表只是传址function readfiletotable(path) --temptable=((type(temptable)=="table") and {temptable} or { {}})[1] --万一是没写入i第二个参数或者第二个参数不是表就给个空表 local temptable={} local i=1 print(path) local file = io.open(path, "r")--找不到并不会自动创建 if file then for line in file:lines() do --使用file:lines()函数逐行读取文件 temptable[i]=line i=i+1 end io.close(file) return temptable else return nil end end--覆盖写入文件内容 失败的话返回nilfunction writefile(path,str) str=tostring(str) or ""--为了避免函数参数不是字符串或为nil 报错 给一个初值 local file = io.open(path, "w")--w模式下如果文件不存在会自动创建 if file then file:write(str) io.close(file) return else return nil end end--追加写入文件内容function appendfile(path,str) str=tostring(str) or ""--为了避免函数参数不是字符串或为nil 报错 给一个初值 local file = io.open(path, "a")--a模式下如果文件不存在会自动创建 if file then file:write(str) io.close(file) return else return nil endend
--判断文件是否存在 返回truefalsefunction zjllib:fileExist(path) local file = io.open(path, "r") if file then io.close(file) return true end return falseend
lua文件操作的lfs库(文件的创建删除复制剪切改名等等操作)
lfs.attributes(filepath [, aname]) 获取路径指定属性
lfs.chdir(path) 改变当前工作目录,成功返回true,失败返回nil加上错误信息 lfs.currentdir 获取当前工作目录,成功返回路径,失败为nil加上错误信息 lfs.dir(path) 返回一个迭代器(function)和一个目录(userdata),每次迭代器都会返回一个路径,直到不是文件目录为止,则迭代器返回nil lfs.lock(filehandle, mode[, start[, length]]) lfs.mkdir(dirname) 创建一个新目录 lfs.rmdir(dirname) 删除一个已存在的目录,成功返回true,失败返回nil加上错误信息 但是不会导致代码崩溃 只是返回2个值 一个是是否成功 另外一个是错误的内容
5 lua的异常处理
其实就是为了避免代码报错导致的整个代码崩溃的情况 就3个函数来处理这些错误避免代码崩溃
assert()
pcall()
xpcall()
基本上在可能报错的函数 用pcall或者xpcall包含住 一旦里面出错 pcall 或者xpcall 只是返回2个值 第一个是是否成功运行true false 第二个是包含的函数的返回值或者错误信息的具体内容
6lua的debug库
Lua内置的调试器用法详解
Lua调试:getinfo详解
7 os.time()的问题
os.time()的问题和解决办法
1.os.clock函数的实现是调用了c语言的函数函数库,实现代码如下:
static int os_clock (lua_State *L) { lua_pushnumber(L, ((lua_Number)clock())/(lua_Number)CLOCKS_PER_SEC); return 1; }
其中有个
CLOCKS_PER_SEC
值,在不同平台有着不同的定义,所以一定要注意函数的溢出问题,程序运行时间太长的话,使用clock
有可能会返回负数。
ANSI clock有三个问题:1)如果超过一个小时,将要导致溢出.2)函数clock没有考虑CPU被子进程使用的情况.3)也不能区分用户空间和内核空间.
果然是老语言 很多东西都不够完善
所以clock函数在linux系统上变得没有意义.
2.使用socket.gettime()函数代替os.clock()
--require "socket" –不太清楚这个方法调用有点问题 只能换个方式socket = require("socket")for i=1,10 do print(socket.gettime())--简单说下这个函数 返回的是以秒为单位的时间戳 但是,默认它有4位小数位, --就是说可以轻松转化为13位的毫秒时间戳 但是注意这个返回值X1000后整体是14位 获取我们需要的13位时间戳 --floor(socket.gettime()*1000) 这样就可以了 print(math.floor(socket.gettime()*1000))--注意获取得是当前系统得时间戳 而不是网络时间戳测试过了 end
8 lua下导入其他文件的2个常见办法
导入模块 require 注意模块的写法有一定要求 就是lua面向对象编程
导入其他lua的代码 dofile 注意dofile “test.lua” 相当于再dofile得位置 执行了一遍test.lua得所有代码
这个办法h很好用 一些常用得自定义函数 或者代码常见的声明区 或者最常见的一些代码初始化区域 都可以单独的放到一个独立lua文件 在别的lua源码中开头直接dofile 当前代码就不用重复的代码初始化之类的重复操作 相当于按键下的import
123