我做了一个简单的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);
}
此代码将运行五到十次左右,然后停止执行任何操作。一些测试显示它确实会传递“延迟(zzz)”代码,但之后再也没有了。
现在就是这样:我接受了“循环”代码并将其移动到一个函数中,我在“循环”部分调用它。并且没有明显的原因,现在它运行并运行没有问题。
我能想到的唯一原因是,如果在“loop()”中实例化的对象没有被正确释放,也许正因为这样,当大量的WiFiClientSecure对象留下时,我会耗尽内存。但这只是一个模糊的猜测 - 我真的很想了解发生了什么! 让它工作是令人满意的,但除非我得到为什么我真的没有学到太多东西! =)
答案 0 :(得分:1)
问题在于,当在主循环中设置延迟时,你基本上阻止了所有后台实用程序功能,这与管理TCP / IP堆栈等有关。
它工作5-10次的原因是由于延迟的随机大小,当延迟太大时代码会崩溃esp。
将代码放入函数会引入一些非阻塞时间,因此在循环的每次迭代中实际上都是“延迟延迟”,因此代码可以工作。