ESP_ERR_NVS_VALUE_TOO_LONG
时间: 2023-08-05 21:06:45 浏览: 263
ESP_ERR_NVS_VALUE_TOO_LONG 错误表示 NVS(Non-Volatile Storage,非易失性存储)中存储的值过长。NVS 是一种用于在闪存中存储和检索数据的机制,每个键值对的值都有一定的长度限制。
当你尝试将一个超过限制长度的值写入 NVS 时,就会出现 ESP_ERR_NVS_VALUE_TOO_LONG 错误。要解决这个问题,你可以采取以下几个步骤:
1. 确认数值长度:检查你要存储的值是否超过了 NVS 的限制长度。不同的硬件平台和开发环境可能有不同的限制,你可以查阅相关文档或参考开发工具的说明。
2. 缩短数值长度:如果你的数值超过了限制长度,你需要缩短它。可以考虑使用更短的字符串、压缩数据或者其他方式来减小数值的长度。
3. 拆分数据:如果你的数据确实需要超过 NVS 的限制长度,你可以考虑将数据拆分成多个部分进行存储。例如,将一个长字符串拆分成多个较小的字符串,并使用不同的键名进行存储。
4. 调整存储类型:某些平台提供了不同类型的 NVS 存储,例如,ESP32 提供了 nvs_set_blob() 函数,可以存储二进制数据。你可以考虑使用适合你数据类型的存储方式。
请注意,每个 NVS 存储的具体实现可能有所不同,因此你需要查阅相关文档或参考特定平台的示例代码来处理 ESP_ERR_NVS_VALUE_TOO_LONG 错误。
相关问题
/* * SPDX-FileCopyrightText: 2015-2022 Espressif Systems (Shanghai) CO LTD * * SPDX-License-Identifier: Unlicense OR CC0-1.0 */ #include <string.h> #include "freertos/FreeRTOS.h" #include "freertos/task.h" #include "esp_log.h" #include "esp_check.h" #include "bsp_board.h" #include "nvs_flash.h" #include "nvs.h" #include "settings.h" static const char *TAG = "settings"; #define NAME_SPACE "sys_param" #define KEY "param" static sys_param_t g_sys_param = {0}; static const sys_param_t g_default_sys_param = { .need_hint = 1, .sr_lang = SR_LANG_EN, .volume = 70, // default volume is 70% }; static esp_err_t settings_check(sys_param_t *param) { esp_err_t ret; ESP_GOTO_ON_FALSE(param->sr_lang < SR_LANG_MAX, ESP_ERR_INVALID_ARG, reset, TAG, "language incorrect"); ESP_GOTO_ON_FALSE(param->volume <= 100, ESP_ERR_INVALID_ARG, reset, TAG, "volume incorrect"); return ret; reset: ESP_LOGW(TAG, "Set to default"); memcpy(&g_sys_param, &g_default_sys_param, sizeof(sys_param_t)); return ret; } esp_err_t settings_read_parameter_from_nvs(void) { nvs_handle_t my_handle = 0; esp_err_t ret = nvs_open(NAME_SPACE, NVS_READONLY, &my_handle); if (ESP_ERR_NVS_NOT_FOUND == ret) { ESP_LOGW(TAG, "Not found, Set to default"); memcpy(&g_sys_param, &g_default_sys_param, sizeof(sys_param_t)); settings_write_parameter_to_nvs(); return ESP_OK; } ESP_GOTO_ON_FALSE(ESP_OK == ret, ret, err, TAG, "nvs open failed (0x%x)", ret); size_t len = sizeof(sys_param_t); ret = nvs_get_blob(my_handle, KEY, &g_sys_param, &len); ESP_GOTO_ON_FALSE(ESP_OK == ret, ret, err, TAG, "can't read param"); nvs_close(my_handle); settings_check(&g_sys_param); return ret; err: if (my_handle) { nvs_close(my_handle); } return ret; } esp_err_t settings_write_parameter_to_nvs(void) { ESP_LOGI(TAG, "Saving settings"); settings_check(&g_sys_param); nvs_handle_t my_handle = {0}; esp_err_t err = nvs_open(NAME_SPACE, NVS_READWRITE, &my_handle); if (err != ESP_OK) { ESP_LOGI(TAG, "Error (%s) opening NVS handle!\n", esp_err_to_name(err)); } else { err = nvs_set_blob(my_handle, KEY, &g_sys_param, sizeof(sys_param_t)); err |= nvs_commit(my_handle); nvs_close(my_handle); } return ESP_OK == err ? ESP_OK : ESP_FAIL; } sys_param_t *settings_get_parameter(void) { return &g_sys_param; }
这段代码是一个设置参数的示例代码。它使用 ESP-IDF(Espressif IoT Development Framework)和 NVS(Non-volatile Storage)来读取和保存系统参数。
首先,我们定义了一些常量和变量。其中,TAG 是用于在日志中标识相关的日志消息的字符串。NAME_SPACE 是用于在 NVS 中保存参数的命名空间。KEY 是参数在 NVS 中的键名。
然后,我们定义了一个 sys_param_t 结构体类型的全局变量 g_sys_param,用于存储系统参数。我们还定义了一个 g_default_sys_param 常量,用于存储默认的系统参数。
接下来,我们定义了一个 settings_check 函数,用于检查系统参数的合法性。在函数中,我们检查了语言类型和音量值是否在有效范围内。如果参数不合法,则将系统参数重置为默认值。
然后,我们定义了 settings_read_parameter_from_nvs 函数,用于从 NVS 中读取系统参数。首先,我们打开 NVS,并检查是否找到了保存的参数。如果没有找到,则将系统参数设置为默认值,并调用 settings_write_parameter_to_nvs 函数将默认值保存到 NVS 中。如果找到了保存的参数,则从 NVS 中读取参数,并进行合法性检查。
接下来,我们定义了 settings_write_parameter_to_nvs 函数,用于将系统参数保存到 NVS 中。首先,我们调用 settings_check 函数对系统参数进行合法性检查。然后,我们打开 NVS,并将系统参数写入 NVS 中。
最后,我们定义了 settings_get_parameter 函数,用于获取当前的系统参数。
以上是一个简单的示例代码,用于读取和保存系统参数到 NVS 中。具体的使用方式和调用逻辑可能根据实际需求而有所不同。如果你需要更详细的说明,请告诉我。
ESP_ERR_NVS_NO_FREE_PAGES
这是一个IT类问题。这个错误代码 "ESP_ERR_NVS_NO_FREE_PAGES" 是针对 ESP32 开发板的错误,表示 Non-Volatile Storage (NVS) 中没有足够的可用页面来存储数据。这通常发生在尝试写入大量数据到NVS时,但NVS中的可用空间已经用尽。解决这个问题的一种方法是清除一些旧数据或者增加NVS的容量。
阅读全文