当代码从 "loop" 移动到单独的函数时,Arduino https 调用工作。为什么?
Arduino https calls work when code is moved from "loop" to separate function. Why?
我做了一个简单的https调用例程,用来测试某个服务器是否回复。它使用 ESP8266WiFi 和 WiFiClientSecure 库。设置部分看起来像这样(当然前面定义了 ssid 和密码):
void setup() {
Serial.begin(115200);
Serial.println();
Serial.print("connecting to ");
Serial.println(ssid);
WiFi.begin(ssid, password);
while (WiFi.status() != WL_CONNECTED) {
delay(500);
Serial.print(".");
}
Serial.println("");
Serial.println("WiFi connected");
Serial.println("IP address: ");
Serial.println(WiFi.localIP());
}
-所以它是示例的复制粘贴,并且工作正常。其余代码也或多或少来自示例,除了我放在循环部分因为我希望它一遍又一遍地重复:
void loop() {
if (WiFi.status() != WL_CONNECTED) {
connectToWifi();
}
WiFiClientSecure client;
Serial.print("connecting to ");
Serial.println(host);
if (!client.connect(host, httpsPort)) {
Serial.println("connection failed");
return;
}
String url = "/Views/Something.aspx";
Serial.print("requesting URL: ");
Serial.println(url);
client.print(String("GET ") + url + " HTTP/1.1\r\n" +
"Host: " + host + "\r\n" +
"User-Agent: BuildFailureDetectorESP8266\r\n" +
"Connection: close\r\n\r\n");
int zzz = random(5000) + 500;
delay(zzz);
}
此代码会 运行 五到十次左右,然后就停止执行任何操作。一些测试显示它确实会通过 "delay(zzz)" 代码,但随后什么也没有发生。
事情是这样的:我把 "loop" 代码移到一个函数中,我从 "loop" 部分调用它。并且没有明显的原因,现在 运行s 和 运行s 没有问题。
我能想到的唯一原因是,如果在 "loop()" 中实例化的对象没有正确释放,也许正因为如此,当一大群WiFiClientSecure 对象仍然存在。但这只是一个模糊的猜测 - 我真的很想了解发生了什么!
让它工作是令人满意的,但除非我明白为什么我真的没有学到太多东西! =)
问题在于,当在主循环中设置延迟时,您实际上是在阻止所有后台实用程序功能,以及与管理 TCP/IP 堆栈等相关的事情。
它运行 5-10 次的原因是延迟的随机大小,当延迟太大时,代码会导致 esp 崩溃。
将代码放入函数中会引入一些非阻塞时间,因此在循环的每次迭代中都有效 "delaying the delay",因此代码有效。
我做了一个简单的https调用例程,用来测试某个服务器是否回复。它使用 ESP8266WiFi 和 WiFiClientSecure 库。设置部分看起来像这样(当然前面定义了 ssid 和密码):
void setup() {
Serial.begin(115200);
Serial.println();
Serial.print("connecting to ");
Serial.println(ssid);
WiFi.begin(ssid, password);
while (WiFi.status() != WL_CONNECTED) {
delay(500);
Serial.print(".");
}
Serial.println("");
Serial.println("WiFi connected");
Serial.println("IP address: ");
Serial.println(WiFi.localIP());
}
-所以它是示例的复制粘贴,并且工作正常。其余代码也或多或少来自示例,除了我放在循环部分因为我希望它一遍又一遍地重复:
void loop() {
if (WiFi.status() != WL_CONNECTED) {
connectToWifi();
}
WiFiClientSecure client;
Serial.print("connecting to ");
Serial.println(host);
if (!client.connect(host, httpsPort)) {
Serial.println("connection failed");
return;
}
String url = "/Views/Something.aspx";
Serial.print("requesting URL: ");
Serial.println(url);
client.print(String("GET ") + url + " HTTP/1.1\r\n" +
"Host: " + host + "\r\n" +
"User-Agent: BuildFailureDetectorESP8266\r\n" +
"Connection: close\r\n\r\n");
int zzz = random(5000) + 500;
delay(zzz);
}
此代码会 运行 五到十次左右,然后就停止执行任何操作。一些测试显示它确实会通过 "delay(zzz)" 代码,但随后什么也没有发生。
事情是这样的:我把 "loop" 代码移到一个函数中,我从 "loop" 部分调用它。并且没有明显的原因,现在 运行s 和 运行s 没有问题。
我能想到的唯一原因是,如果在 "loop()" 中实例化的对象没有正确释放,也许正因为如此,当一大群WiFiClientSecure 对象仍然存在。但这只是一个模糊的猜测 - 我真的很想了解发生了什么! 让它工作是令人满意的,但除非我明白为什么我真的没有学到太多东西! =)
问题在于,当在主循环中设置延迟时,您实际上是在阻止所有后台实用程序功能,以及与管理 TCP/IP 堆栈等相关的事情。
它运行 5-10 次的原因是延迟的随机大小,当延迟太大时,代码会导致 esp 崩溃。
将代码放入函数中会引入一些非阻塞时间,因此在循环的每次迭代中都有效 "delaying the delay",因此代码有效。