我遇到了一种奇怪的行为。我使用ESP8266 arduino SPIFFS来存储配置设置。这是mycode的相关部分;
void loop()
{
handleUartRxOk();
}
void handleUartRxOk() {
String cmd;
char charBuff[3200];
char char_print[50];
static bool terminatorReceived = false;
char incomingChar = 0; // for incoming serial data
if (Serial.available()) {
incomingChar = Serial.read();
saveChar(incomingChar);
if (incomingChar == '\r') {
terminatorReceived = true;
}
if (terminatorReceived) {
buffer[buffer_index - 1] = '\0';
cmd = String(buffer);
if (cmd == "XXX") {
ConfigSettings.ssid = "SSID_XX";
ConfigSettings.password = "PASSWORD_XX";
saveConfig();
}
buffer_index = 0;
terminatorReceived = false;
}
}
}
在上面的代码中,UART将收到一个命令“XXX \ r \ n”,然后运行saveConfig(),它将配置参数ssid和参数保存到SPIFSS中。此代码完全正常,直到我添加更多完全不相关的代码。
这就是新代码的样子。
void handleUartRxOk() {
String cmd;
char charBuff[3200];
char char_print[50];
static bool terminatorReceived = false;
char incomingChar = 0; // for incoming serial data
if (Serial.available()) {
incomingChar = Serial.read();
saveChar(incomingChar);
if (incomingChar == '\r') {
terminatorReceived = true;
}
if (terminatorReceived) {
buffer[buffer_index - 1] = '\0';
cmd = String(buffer);
if (cmd == "XXX") {
ConfigSettings.ssid = "SSID_XX";
ConfigSettings.password = "PASSWORD_XX";
saveConfig();
}
//Why does adding this else statement cause saveConfig() to crash when run?
else {
strcat(charBuff, cmd.c_str());
}
buffer_index = 0;
terminatorReceived = false;
}
}
}
添加其他else子句后,向UARt发送“XXX \ r”并导致saveConfig()将导致异常错误。这令人费解,因为新代码甚至无法运行。
异常错误如下;
Exception (3):
epc1=0x401002f0 epc2=0x00000000 epc3=0x00000000 excvaddr=0x400072f6 depc=0x00000
000
ctx: sys
sp: 3fff06b0 end: 3fffffb0 offset: 01a0
答案 0 :(得分:2)
将char charBuff[3200];
声明为全局而不是函数内部。 Arduino ESP8266的默认堆栈大小约为4k。您的阵列大小有溢出的风险。试一试,看看它是否有效。我之前遇到过类似的问题。它对我有用。
通过修改cores / esp8266 /
下的cont.h,可以在内存限制内提高默认堆栈大小编辑:Daniel Minion在评论中提供了有关修改默认堆栈大小的信息。