nvm
 Table of Contents
 nvm
 nvm.init(defaultCfgFile, burnSave)
 nvm.set(k, v, r, s)
 nvm.sett(k, kk, v, r, s)
 nvm.flush()
 nvm.get(k)
 nvm.gett(k, kk)
 nvm.restore()
 nvm.remove()
 nvm
 模块功能:参数管理
nvm.init(defaultCfgFile, burnSave)
 初始化参数存储管理模块
参数
 名称 传入值类型 释义
 defaultCfgFile string 默认参数文件名
 burnSave bool 本地烧录时是否保留已有参数,true为保留,false或者nil为清除
 注意:在同一个项目,不同版本中,此参数必须保持前后版本一致
 返回值
 nil
例子
 – 初始化参数存储管理模块,默认参数文件名为config.lua,本地烧录时清除已有的参数:
 nvm.init(“config.lua”)
 – 初始化参数存储管理模块,默认参数文件名为config.lua,本地烧录时保留已有的参数:
 nvm.init(“config.lua”,true)
 详细指南和示例参考:指南 示例
nvm.set(k, v, r, s)
 设置某个参数的值
参数
 名称 传入值类型 释义
 k string 参数名
 v param 参数的新值,仅支持number、string、boolean、table类型
 r param 设置原因,如果传入了非nil的有效参数,并且v值和旧值相比发生了改变,
 会产生一个PARA_CHANGED_IND内部消息,携带 k,v,r 3个参数
 s param 是否立即写入到文件系统中,false不写入,其余的都写入
 返回值
 bool或者nil,成功返回true,失败返回nil
例子
 – 参数name赋值为Luat,立即写入文件系统:
 nvm.set(“name”,“Luat”)
 – 参数age赋值为12,立即写入文件系统:
 – 如果旧值不是12,会产生一个PARA_CHANGED_IND消息,携带 “age”,12,“SVR” 3个参数:
 nvm.set(“age”,12,“SVR”)
 – 参数class赋值为Class2,不写入文件系统:
 nvm.set(“class”,“Class2”,nil,false)
 – 参数score赋值为{chinese=100,math=99,english=98},立即写入文件系统:
 nvm.set(“score”,{chinese=100,math=99,english=98})
 – 连续写入4个参数,前3个不保存到文件系统中,写第4个时,一次性全部保存到文件系统中:
 nvm.set(“para1”,1,nil,false)
 nvm.set(“para2”,2,nil,false)
 nvm.set(“para3”,3,nil,false)
 nvm.set(“para4”,4)
 详细指南和示例参考:指南 示例
nvm.sett(k, kk, v, r, s)
 设置某个table类型参数的某一个索引的值
参数
 名称 传入值类型 释义
 k string table类型的参数名
 kk param table类型参数的某一个索引名
 v param table类型参数的某一个索引的新值
 r param 设置原因,如果传入了非nil的有效参数,并且v值和旧值相比发生了改变,会产生一个TPARA_CHANGED_IND消息,携带k,kk,v,r4个参数
 s param 是否立即写入到文件系统中,false不写入,其余的都写入
 返回值
 bool或者nil,成功返回true,失败返回nil
例子
 nvm.sett(“score”,“chinese”,100),参数score[“chinese”]赋值为100,立即写入文件系统
 nvm.sett(“score”,“chinese”,100,“SVR”),参数score[“chinese”]赋值为100,立即写入文件系统,
 – 如果旧值不是100,会产生一个TPARA_CHANGED_IND消息,携带 “score”,“chinese”,100,“SVR” 4个参数
 nvm.sett(“score”,“chinese”,100,nil,false),参数class赋值为Class2,不写入文件系统
 详细指南和示例参考:指南 示例
nvm.flush()
 所有参数立即写入文件系统
参数
 无
返回值
 nil
例子
 nvm.flush()
 nvm.get(k)
 读取某个参数的值
参数
 名称 传入值类型 释义
 k string 参数名
 返回值
 参数值
例子
 – 读取参数名为name的参数值:
 nameValue = nvm.get(“name”)
 详细指南和示例参考:指南 示例
nvm.gett(k, kk)
 读取某个table类型参数的键名对应的值
参数
 名称 传入值类型 释义
 k string table类型的参数名
 kk param table类型参数的键名
 返回值
 无
例子
 – 有一个table参数为score,数据如下:
 score = {chinese=100, math=100, english=95}
 – 读取score中chinese对应的值:
 nvm.gett(“score”,“chinese”)
 详细指南和示例参考:指南 示例
nvm.restore()
 参数恢复出厂设置
参数
 无
返回值
 nil
例子
 nvm.restore()
 详细指南和示例参考:指南 示例
nvm.remove()
 请求删除参数文件.
此接口一般用在远程升级时,需要用新的config.lua覆盖原来的参数文件的场景,在此场景下,远程升级包下载成功后,在确定要重启前调用此接口
 下次开机执行nvm.init(“config.lua”)时,会用新的config.lua文件自动覆盖参数文件;以后再开机就不会自动覆盖了
 也就是说"nvm.remove()->重启->nvm.init(“config.lua”)"是一个仅执行一次的完整操作
参数
 无
返回值
 nil
例子
 nvm.remove()
 详细指南和示例参考:指南 示例