用arduinoIDE编程ESP8266NodeMcu时,定义的全局变量String最多包含多少个字符
时间: 2024-06-01 21:10:32 浏览: 91
在ESP8266NodeMcu上使用Arduino IDE编程时,String类型的全局变量最多可以包含约4KB的字符。这是由于ESP8266NodeMcu的内存限制所决定的。建议尽可能避免使用过多的String类型变量,以避免内存不足的问题。可以使用C语言中的char数组类型代替String类型,以减少内存占用。
相关问题
在ESP8266NodeMcu上使用Arduino IDE编程时,String类型的全局变量最多可以包含约4KB的字符,这个4KB是怎么得出来的,请详细解释,String类型的全局变量被存储在内存的哪个区域,请详细解释
ESP8266NodeMcu是一款基于ESP8266芯片的开发板,它可以使用Arduino IDE进行编程。在Arduino IDE中,String类型的全局变量最多可以包含约4KB的字符,这是因为ESP8266芯片内存分为三个部分,分别是:
1. 程序存储区(Flash):用于存储程序的代码和数据,大小为4MB。在程序运行时,Flash中的程序代码会被加载到RAM中执行。
2. 数据存储区(RAM):用于存储程序运行时产生的数据,大小为80KB。在程序运行过程中,RAM中的数据可以被读取、修改和删除。
3. 文件存储区(SPIFFS):用于存储文件,大小为1MB。可以将文件存储在SPIFFS中,比如HTML、CSS、JS等。
由于String类型的全局变量是存储在RAM中的,所以它的最大容量受到RAM大小的限制。ESP8266NodeMcu的RAM大小为80KB,因此String类型的全局变量最多可以包含约4KB的字符。
需要注意的是,ESP8266芯片具有一定的片上存储器,可以存储一些常量数据,比如WiFi网络的SSID和密码等。这些常量数据并不占用RAM空间,因此可以在程序中使用const char*类型变量来存储这些数据,而不会受到RAM大小的限制。
/* * 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 中。具体的使用方式和调用逻辑可能根据实际需求而有所不同。如果你需要更详细的说明,请告诉我。
阅读全文