Air780EP模块fskv开发示例
简介
-
兼容fdb的函数
-
使用fdb的flash空间,启用时也会替代fdb库
- 功能上与EEPROM是类似的
fskv与fdb的实现机制导致的差异
功能 | fskv | fdb |
---|---|---|
value长度 | 4096 | 255 |
key长度 | 63 | 64 |
空间利用率(对比) | 较低 | 较高 |
读取速度 | 恒定 | 脏数据影响速度,非恒定 |
写入数据 | 恒定 | 脏数据影响速度,非恒定 |
均衡擦除 | 自动 | 自动 |
1、环境准备
1、780EP开发板一套
程序介绍
API介绍
详细API介绍见:fskv-API
初始化kv数据库
fskv.init()
参数
无
返回值
返回值类型 | 解释 |
---|---|
boolean | 成功返回true,否则返回false |
设置一对kv数据
fskv.set(key, value)
参数
传入值类型 | 解释 |
---|---|
string | key的名称,必填,不能空字符串 |
string | 用户数据,必填,不能nil, 支持字符串/数值/table/布尔值, 数据长度最大4095字节 |
返回值
返回值类型 | 解释 |
---|---|
boolean | 成功返回true,否则返回false |
设置table内的键值对数据
fskv.sett(key, skey, value)
参数
传入值类型 | 解释 |
---|---|
string | key的名称,必填,不能空字符串 |
string | table的key名称, 必填, 不能是空字符串 |
string | 用户数据,必填,支持字符串/数值/table/布尔值, 数据长度最大4095字节 |
返回值
返回值类型 | 解释 |
---|---|
boolean | 成功返回true,否则返回false/nil |
根据key获取对应的数据
fskv.get(key, skey)
参数
传入值类型 | 解释 |
---|---|
string | key的名称,必填,不能空字符串 |
string | 可选的次级key,仅当原始值为table时有效,相当于 fskv.get(key)[skey] |
返回值
返回值类型 | 解释 |
---|---|
any | 存在则返回数据,否则返回nil |
根据key删除数据
fskv.del(key)
参数
传入值类型 | 解释 |
---|---|
string | key的名称,必填,不能空字符串 |
返回值
返回值类型 | 解释 |
---|---|
bool | 成功返回true,否则返回false |
清空整个kv数据库
fskv.clear()
参数
无
返回值
返回值类型 | 解释 |
---|---|
bool | 成功返回true,否则返回false |
kv数据库迭代器
fskv.iter()
参数
无
返回值
返回值类型 | 解释 |
---|---|
userdata | 成功返回迭代器指针,否则返回nil |
kv迭代器获取下一个key
fskv.next(iter)
参数
传入值类型 | 解释 |
---|---|
userdata | fskv.iter()返回的指针 |
返回值
返回值类型 | 解释 |
---|---|
string | 成功返回字符串key值, 否则返回nil |
获取kv数据库状态
fskv.status()
参数
无
返回值
返回值类型 | 解释 |
---|---|
int | 已使用的空间,单位字节 |
int | 总可用空间, 单位字节 |
int | 总kv键值对数量, 单位个 |
实现流程
使用luatools工具下载固件和脚本到开发板中
通过luatools打印查看效果:
由上图可以看出,fskv支持存放布尔,数值,小数,字符串,等均可。还可以存放table类型的值。 但不能存放nil, function, userdata, task类型的值。
常见问题:
NVM坏了的话会不会影响fskv存储?
不同的flash互不影响。