main.lua 3.0 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293
  1. -- LuaTools需要PROJECT和VERSION这两个信息
  2. PROJECT = "fdbdemo"
  3. VERSION = "1.0.0"
  4. -- sys库是标配
  5. _G.sys = require("sys")
  6. sys.taskInit(function()
  7. sys.wait(1000) -- 免得日志刷了, 生产环境不需要
  8. -- 检查一下当前固件是否支持fdb
  9. if not fdb then
  10. while true do
  11. log.info("fdb", "this demo need fdb")
  12. sys.wait(1000)
  13. end
  14. end
  15. -- 初始化kv数据库
  16. fdb.kvdb_init("onchip_flash")
  17. log.info("fdb", "init complete")
  18. -- 先放入一堆值
  19. local bootime = fdb.kv_get("boottime")
  20. if bootime == nil or type(bootime) ~= "number" then
  21. bootime = 0
  22. else
  23. bootime = bootime + 1
  24. end
  25. fdb.kv_set("boottime", bootime)
  26. fdb.kv_set("my_bool", true)
  27. fdb.kv_set("my_int", 123)
  28. fdb.kv_set("my_number", 1.23)
  29. fdb.kv_set("my_str", "luatos")
  30. fdb.kv_set("my_table", {name="wendal",age=18})
  31. fdb.kv_set("my_str_int", "123")
  32. fdb.kv_set("1", "123") -- 单字节key
  33. --fdb.kv_set("my_nil", nil) -- 会提示失败,不支持空值
  34. log.info("fdb", "boottime", type(fdb.kv_get("boottime")), fdb.kv_get("boottime"))
  35. log.info("fdb", "my_bool", type(fdb.kv_get("my_bool")), fdb.kv_get("my_bool"))
  36. log.info("fdb", "my_int", type(fdb.kv_get("my_int")), fdb.kv_get("my_int"))
  37. log.info("fdb", "my_number", type(fdb.kv_get("my_number")), fdb.kv_get("my_number"))
  38. log.info("fdb", "my_str", type(fdb.kv_get("my_str")), fdb.kv_get("my_str"))
  39. log.info("fdb", "my_table", type(fdb.kv_get("my_table")), json.encode(fdb.kv_get("my_table")))
  40. log.info("fdb", "my_str_int", type(fdb.kv_get("my_str_int")), fdb.kv_get("my_str_int"))
  41. log.info("fdb", "1 byte key", type(fdb.kv_get("1")), json.encode(fdb.kv_get("1")))
  42. -- 删除测试
  43. fdb.kv_del("my_bool")
  44. local t = fdb.kv_get("my_bool")
  45. log.info("fdb", "my_bool", type(t), t)
  46. if fdb.kv_iter then
  47. local iter = fdb.kv_iter()
  48. if iter then
  49. while 1 do
  50. local k = fdb.kv_next(iter)
  51. if not k then
  52. log.info("fdb", "iter exit")
  53. break
  54. end
  55. log.info("fdb", k, "value", fdb.kv_get(k))
  56. end
  57. else
  58. log.info("fdb", "iter is null")
  59. end
  60. else
  61. log.info("fdb", "without iter")
  62. end
  63. -- 压力测试
  64. local start = mcu.ticks()
  65. local count = 1000
  66. while count > 0 do
  67. -- sys.wait(10)
  68. count = count - 1
  69. -- fdb.kv_set("BENT1", "--" .. os.date() .. "--")
  70. -- fdb.kv_set("BENT2", "--" .. os.date() .. "--")
  71. -- fdb.kv_set("BENT3", "--" .. os.date() .. "--")
  72. -- fdb.kv_set("BENT4", "--" .. os.date() .. "--")
  73. fdb.kv_get("my_bool")
  74. end
  75. log.info("fdb", (mcu.ticks() - start) / 1000)
  76. end)
  77. -- 用户代码已结束---------------------------------------------
  78. -- 结尾总是这一句
  79. sys.run()
  80. -- sys.run()之后后面不要加任何语句!!!!!