【esp32 学习笔记】NVS分区永久保存数据

转载自:https://www.elecfans.com/d/2184353.html

 

今天我们来说说ESP32 for Arduino NVS分区永久保存数据。

ESP32 for Arduino NVS分区

上一节我们讲了整个ESP32的存储分布,其中有一个NVS分区,这个分区专门用来存储数据的,系统在复位或断电后数据仍然存在,我们可以使用Preferences库保存网络SSID,密码,一些阈值或者IO的最后状态等。

 

在保存数据的时候,我们推荐使用Preferences库,不推荐使用EEPROM库。

使用Preferences库保存的数据结构如下,也叫键值对:

namespace {
  key:value
}

一个命名空间中也可以有不同的键:

namespace {
  key1: value1
  key2: value2
}

实际使用中,我们可以用来保存网络凭证:

credentials {
  ssid: "your_ssid"
  pass: "your_pass"
}

也可以有多个具有相同键的命名空间(但每个键都有其值):

namespace1{
  key:value1
}
namespace2{
  key:value2
}

使用Preferences库时,应该定义要保存的数据类型。如果想读取该数据,则必须知道保存的数据类型,也就是说,写入和读取的数据类型应该相同。

支持以下数据类型的保存:char、char、short、Ushort、int、Uint、long、Ulong、long64、Ulong64、float、double、bool、字符串和字节。

Preferences库函数说明

首先包含头文件

Preferences 库

然后定义一个实例

Preferences preferences;

打开一个命名空间

begin方法打开一个带有定义命名空间的“储存空间”,参数为false代表我们在读/写模式下使用,为true代表以只读的方式打开或创建命令空间,命名空间名称最多为15个字符。

preferences.begin("my-app", false);

清除preferences

从打开的命名空间中删除一个键。

preferences.remove(key);

关闭preferences

使用end方法在打开的命名空间下关闭preferences

preferences.end();

放置一个k-v

图片

获取一个k-v

图片

删除命名空间

在Preferences 库中,并没有完全删除命令空间的方法,我们存储很多数据之后,nvs分区可能就满了,所以我们想要完全擦除nvs分区,可以使用以下程序运行一次:

#include < nvs_flash.h >

void setup() {
  nvs_flash_erase(); // 擦除NVS分区
  nvs_flash_init();  // 初始化NVS分区
  while(true);
}

void loop() {

}

程序示例

我们直接打开Example中的例子,StartCounter

/*
 ESP32 startup counter example with Preferences library.

 This simple example demonstrates using the Preferences library to store how many times the ESP32 module has booted. 
 The Preferences library is a wrapper around the Non-volatile storage on ESP32 processor.

 created for arduino-esp32 09 Feb 2017 by Martin Sloup (Arcao)
 
 Complete project details at https://RandomNerdTutorials.com/esp32-save-data-permanently-preferences/
*/

#include < Preferences.h >

Preferences preferences;

void setup() {
  Serial.begin(115200);
  Serial.println();

  // Open Preferences with my-app namespace. Each application module, library, etc
  // has to use a namespace name to prevent key name collisions. We will open storage in
  // RW-mode (second parameter has to be false).
  // Note: Namespace name is limited to 15 chars.
  preferences.begin("my-app", false);

  // Remove all preferences under the opened namespace
  //preferences.clear();

  // Or remove the counter key only
  //preferences.remove("counter");

  // Get the counter value, if the key does not exist, return a default value of 0
  // Note: Key name is limited to 15 chars.
  unsigned int counter = preferences.getUInt("counter", 0);

  // Increase counter by 1
  counter++;

  // Print the counter to Serial Monitor
  Serial.printf("Current counter value: %un", counter);

  // Store the counter to the Preferences
  preferences.putUInt("counter", counter);

  // Close the Preferences
  preferences.end();

  // Wait 10 seconds
  Serial.println("Restarting in 10 seconds...");
  delay(10000);

  // Restart ESP
  ESP.restart();
}

void loop() {

}

这个例子增加了一个counter键,每次运行都加一,我们在按下复位键之后,可以看到下面你的现象,数据保存起来了。

图片

Preferences库很方便保存键:值对。即使在重置 ESP32 或断电后,闪存中保存的数据仍然存在。

感谢大家,关于ESP32的学习,希望大家Enjoy!

posted @ 2024-06-11 18:52  FBshark  阅读(305)  评论(0编辑  收藏  举报