// ArduinoJson - https://arduinojson.org // Copyright © 2014-2022, Benoit BLANCHON // MIT License // // This example shows the different ways you can use Flash strings with // ArduinoJson. // // Use Flash strings sparingly, because ArduinoJson duplicates them in the // JsonDocument. Prefer plain old char*, as they are more efficient in term of // code size, speed, and memory usage. // // https://arduinojson.org/v6/example/progmem/ #include void setup() { DynamicJsonDocument doc(1024); // You can use a Flash String as your JSON input. // WARNING: the strings in the input will be duplicated in the JsonDocument. deserializeJson(doc, F("{\"sensor\":\"gps\",\"time\":1351824120," "\"data\":[48.756080,2.302038]}")); JsonObject obj = doc.as(); // You can use a Flash String to get an element of a JsonObject // No duplication is done. long time = obj[F("time")]; // You can use a Flash String to set an element of a JsonObject // WARNING: the content of the Flash String will be duplicated in the // JsonDocument. obj[F("time")] = time; // You can set a Flash String to a JsonObject or JsonArray: // WARNING: the content of the Flash String will be duplicated in the // JsonDocument. obj["sensor"] = F("gps"); // It works with serialized() too: obj["sensor"] = serialized(F("\"gps\"")); obj["sensor"] = serialized(F("\xA3gps"), 3); // You can compare the content of a JsonVariant to a Flash String if (obj["sensor"] == F("gps")) { // ... } } void loop() { // not used in this example } // See also // -------- // // https://arduinojson.org/ contains the documentation for all the functions // used above. It also includes an FAQ that will help you solve any memory // problem. // // The book "Mastering ArduinoJson" contains a quick C++ course that explains // how your microcontroller stores strings in memory. It also tells why you // should not abuse Flash strings with ArduinoJson. // Learn more at https://arduinojson.org/book/ // Use the coupon code TWENTY for a 20% discount ❤❤❤❤❤