@[TOC] # nvm 模块功能:参数管理 ## nvm.init(defaultCfgFile, burnSave) 初始化参数存储管理模块 * 参数 |名称|传入值类型|释义| |-|-|-| |defaultCfgFile|string|默认参数文件名| |burnSave|bool|本地烧录时是否保留已有参数,true为保留,false或者nil为清除
注意:在同一个项目,不同版本中,此参数必须保持前后版本一致| * 返回值 nil * 例子 ```lua -- 初始化参数存储管理模块,默认参数文件名为config.lua,本地烧录时清除已有的参数: nvm.init("config.lua") -- 初始化参数存储管理模块,默认参数文件名为config.lua,本地烧录时保留已有的参数: nvm.init("config.lua",true) ``` --- ## nvm.set(k, v, r, s) 设置某个参数的值 * 参数 |名称|传入值类型|释义| |-|-|-| |k|string|参数名| |v|param|可以是任意类型,参数的新值| |r|param|设置原因,如果传入了非nil的有效参数,并且v值和旧值相比发生了改变,
会产生一个PARA_CHANGED_IND内部消息,携带 k,v,r 3个参数| |s|param|是否立即写入到文件系统中,false不写入,其余的都写入| * 返回值 bool或者nil,成功返回true,失败返回nil * 例子 ```lua -- 参数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 * 例子 ```lua 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 * 例子 ```lua nvm.flush() ``` --- ## nvm.get(k) 读取某个参数的值 * 参数 |名称|传入值类型|释义| |-|-|-| |k|string|参数名| * 返回值 参数值 * 例子 ```lua -- 读取参数名为name的参数值: nameValue = nvm.get("name") ``` --- ## nvm.gett(k, kk) 读取某个table类型参数的键名对应的值 * 参数 |名称|传入值类型|释义| |-|-|-| |k|string|table类型的参数名| |kk|param|table类型参数的键名| * 返回值 无 * 例子 ```lua -- 有一个table参数为score,数据如下: score = {chinese=100, math=100, english=95} -- 读取score中chinese对应的值: nvm.gett("score","chinese") ``` --- ## nvm.restore() 参数恢复出厂设置 * 参数 无 * 返回值 nil * 例子 ```lua nvm.restore() ``` --- ## nvm.remove() 请求删除参数文件. 此接口一般用在远程升级时,需要用新的config.lua覆盖原来的参数文件的场景,在此场景下,远程升级包下载成功后,在确定要重启前调用此接口
下次开机执行nvm.init("config.lua")时,会用新的config.lua文件自动覆盖参数文件;以后再开机就不会自动覆盖了
也就是说"nvm.remove()->重启->nvm.init("config.lua")"是一个仅执行一次的完整操作 * 参数 无 * 返回值 nil * 例子 ```lua nvm.remove() ``` ---