当代码从“循环”移动到单独的函数时,Arduino https调用工作。为什么?

时间:2016-10-21 14:56:47

标签: arduino client esp8266

我做了一个简单的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对象留下时,我会耗尽内存。但这只是一个模糊的猜测 - 我真的很想了解发生了什么! 让它工作是令人满意的,但除非我得到为什么我真的没有学到太多东西! =)

1 个答案:

答案 0 :(得分:1)

问题在于,当在主循环中设置延迟时,你基本上阻止了所有后台实用程序功能,这与管理TCP / IP堆栈等有关。

它工作5-10次的原因是由于延迟的随机大小,当延迟太大时代码会崩溃esp。

将代码放入函数会引入一些非阻塞时间,因此在循环的每次迭代中实际上都是“延迟延迟”,因此代码可以工作。