当代码从 "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",因此代码有效。