ArduinoJson库 V6版本以及相关函数介绍

ArduinoJson库 V6版本以及相关函数介绍

ArduinoJson V6版本和V5版本

版本差异:https://arduinojson.org/v6/doc/upgrade/

一.V6版本函数库结构

List item

主要分为四大类

一.JsonDocument相关,

二. JsonObject相关;

三.JsonArray相关;

四.解析、构造相关;

二.最重要的JSONDOCUMENT

1.两个实现类:

DYNAMICJSONDOCUMENT

  • DYNAMICJSONDOCUMENT
    内存分配在heap区,无固定大小,可以自动增长所需空间,方法调用完自动回收,建议内存大小,大于1KB使用;
DynamicJsonDocument doc(2048); //创建一个DynamicJsonDocument类型的doc对象,大小2048byte

STATICJSONDOCUMENT

  • STATICJSONDOCUMENT
    内存分配在stack区,有固定大小,大小值由开发者定义,方法调用完自动回收,建议内存大小,小于1KB使用;
StaticJsonDocument<256> doc;

官网原文

Use a StaticJsonDocument to store in the stack (recommended for documents smaller than 1KB)
Use a DynamicJsonDocument to store in the heap (recommended for documents larger than 1KB)

2.使用JSONDOCUMENT

JSONDOCUMENT 创建一个JsonDocument之后,默认初始化为空,调用 JsonDocument::isNull()会返回true,这个时候既可以代表当做jsonObject,也可以当做jsonArray,这取决于你插入第一个value的类型。
例1: doc 作为JsonObject使用

DynamicJsonDocument doc(1024);
doc["answer"] = 42;
// the doc contains {"answer":42}

例2: doc 作为JsonArray使用

DynamicJsonDocument doc(1024);
doc.add(42);
// the doc contains [42]

3.AS —— 获取顶节点,并把它转成T类型

DynamicJsonBuffer doc(1024);
deserializeJson(doc, "{\"key\":\"value\")");
 
// get the JsonObject in the JsonDocument
JsonObject root = doc.as<JsonObject>();
 
// get the value in the JsonObject
const char* value = root["key"];
  • 此方法不会改变 JsonDocument的内容(JsonDocument::to()会改变)
  • 此方法只会返回JsonDocument顶节点的引用。如果顶节点的类型和强转的T类型不匹配,此方法将会返回空引用

4.TO —— JSONDOCUMENT转成T类型

函数说明:

/**
 * jsondocument转成T类型,T为JsonArray、JsonObject、JsonVariant
 */
JsonArray   to<JsonArray>();
JsonObject  to<JsonObject>();
JsonVariant to<JsonVariant>();

此方法是释放jsondocument的内存空间,也就是说之前已经分配的引用无效,参考代码:

DynamicJsonBuffer doc(1024);
 
JsonObject root1 = doc.to<JsonObject>();
 
JsonObject root2 = doc.to<JsonObject>();
 
// Don't use root1 here, because it's dangling!

5.CLEAR —— 清除JSONDOCUMENT并释放内存空间

清除JsonDocument并释放内存空间

doc.clear();

6. ISNULL —— 判断JSONDOCUMENT是否为空

/**
 * 判断jsondocument是否为空
 */
bool isNull() const;

7. MEMORYUSAGE —— JSONDOCUMENT已使用内存字节数

函数说明:

/**
 * jsondocument已使用内存字节数
 */
size_t memoryUsage() const;

REMOVE —— 移除特定KEY和VALUE

results.remove(0);
  root.remove("results");

三. 解析构造相关

1.DESERIALIZEJSON —— 解析JSON

/**
 * 解析json
 * @param doc jsondocument对象
 * @param input 输入内容
 * @return DeserializationError 解析结果
 */
// writable input => zero-copy
DeserializationError deserializeJson(JsonDocument& doc, char* input);
DeserializationError deserializeJson(JsonDocument& doc, char* input, size_t inputSize);
 
// read-only input => duplication
DeserializationError deserializeJson(JsonDocument& doc, const char* input);
DeserializationError deserializeJson(JsonDocument& doc, const char* input, size_t inputSize);
DeserializationError deserializeJson(JsonDocument& doc, const __FlashStringHelper* input);
DeserializationError deserializeJson(JsonDocument& doc, const __FlashStringHelper* input, size_t inputSize);
DeserializationError deserializeJson(JsonDocument& doc, const String& input);
DeserializationError deserializeJson(JsonDocument& doc, const std::string& input);
DeserializationError deserializeJson(JsonDocument& doc, Stream& input);
DeserializationError deserializeJson(JsonDocument& doc, std::istream& input);

例子:

const char* json = "{\"hello\":\"world\"}";
StaticJsonDocument<200> doc;
deserializeJson(doc, json);
const char* world = doc["hello"];

2. SERIALIZEJSON —— 构造序列化JSON (串口打印JSON)

StaticJsonDocument<200> doc;
doc["hello"] = "world";
serializeJson(doc, Serial);

3. SERIALIZEJSONPRETTY —— 构造序列化JSON,格式化输出 (串口美化打印JSON)

/**
 * 构造序列化json,格式化输出
 * @param doc jsondocument对象
 * @param output 输出内容
 */
size_t serializeJsonPretty(const JsonDocument& doc, char* output, size_t outputSize);
size_t serializeJsonPretty(const JsonDocument& doc, char output[size]);
size_t serializeJsonPretty(const JsonDocument& doc, Print& output);
size_t serializeJsonPretty(const JsonDocument& doc, String& output);
size_t serializeJsonPretty(const JsonDocument& doc, std::string& output);

4. MEASUREJSON —— 计算构造序列化JSON的长度

/**
 * 计算构造序列化格式化json的长度
 * @param doc jsondocument对象
 * @Note 关联方法  serializeJsonPretty
 */
size_t measureJsonPretty(const JsonDocument& doc);

5. MEASUREJSONPRETTY —— 计算构造序列化格式化JSON的长度

/**
 * 计算构造序列化格式化json的长度
 * @param doc jsondocument对象
 * @Note 关联方法  serializeJsonPretty
 */
size_t measureJsonPretty(const JsonDocument& doc);

四. JSONOBJECT相关函数

在JsonDocument所构造出来的内存空间中,Json对象的入口就是JsonObject。

1. CONTAINSKEY —— 判断对象是否包含某一个KEY

bool hasCity = root.containsKey("city"); // true

2. CREATENESTEDARRAY —— 在当前对象中添加子KEY,子VALUE为JSON数组

StaticJsonDocument<256> doc;
JsonObject root = doc.to<JsonObject>();
root["status"] = "on";
JsonArray levels = root.createNestedArray("levels");
levels.add(10);
levels.add(30);
serializeJsonPretty(root, Serial);

结果:

{
  "status": "on",
  "levels": [
    10,
    20
  ]
}

3. CREATENESTEDOBJECT —— 在当前对象中添加子KEY,子VALUE为JSON对象

StaticJsonDocument<256> doc;
JsonObject root = doc.to<JsonObject>();
root["city"] = "Paris";
JsonObject weather = root.createNestedObject("weather");
weather["temp"] = 14.2;
weather["cond"] = "cloudy";
serializeJsonPretty(root, Serial);

4. GETMEMBER —— 获取KEY对应的VALUE (仅限JSONOBJECT类型)

/**
 * 获取key对应的value
 * @param key 对应的key
 * @param JsonVariant key对应的value,如果不匹配返回null
 */
JsonVariant getMember(const char* key);
JsonVariant getMember(String key);
JsonVariant getMember(std::string key);
JsonVariant getMember(const __FlashStringHelper* key);

5. GETORCREATEMEMBER —— 获取或者创建KEY对应的VALUE(仅限JSONOBJECT类型)

/**
 * 获取或者创建key对应的value
 * @param key 对应的key
 * @param JsonVariant key对应的value,如果不匹配返回null
 */
JsonVariant getOrCreateMember(const char* key);
JsonVariant getOrCreateMember(String key);
JsonVariant getOrCreateMember(std::string key);
JsonVariant getOrCreateMember(const __FlashStringHelper* key);
  • 如果JsonDocument包含一个对象,那么getOrCreateMember方法会获取指定key的值,如果对象不存在该key,这个方法会往对象添加一个新的key-value键值对;
  • 如果JsonDocument是空,那么getOrCreateMember方法将创建一个对象给到JsonDocument;
  • 如果属于以上两种情况之外的,此方法无效;

五. JSONARRAY相关函数

1. ADD —— 往JSONARRAY中添加元素 (仅限JSONARRAY类型)

StaticJsonDocument<200> doc;
array.add("hello"); // null -> ["hello"]
array.add(3.14156); // ["hello"] -> ["hello",3.14156]
serializeJson(doc, Serial);
  • 如果JsonDocument顶节点是一个JsonArray,add方法会追加一个value到数组;
  • 如果JsonDocument顶节点是一个JsonObject,add无效;
  • 如果JsonDocument是一个空对象,add方法会把JsonDocument变成一个包含一个元素的数组,这是一个创建数组的方式;

2. CREATENESTEDARRAY —— 添加JSON数组

StaticJsonDocument<200> doc;
JsonArray array = doc.to<JsonArray>();
array.add("hello");
JsonArray nested = array.createNestedArray();
nested.add("world");
serializeJson(array, Serial);

结果:

["hello",["world"]]

3. CREATENESTEDOBJECT —— 添加JSON对象

StaticJsonDocument<200> doc;
JsonArray array = doc.to<JsonArray>();
JsonObject nested = array.createNestedObject();
nested["hello"] = "world";
serializeJson(array, Serial);

结果:

[{"hello":"world"}]

4. GETELEMENT —— 获取INDEX位置的元素(仅限JSONARRAY类型)

/**
 * 获取index位置/key的元素
 * @param index 索引位置
 * @return JsonVariant 如果找不到匹配的返回null
 */
JsonVariant getElement(size_t index);

5. GETORADDELEMENT —— 获取或者创建INDEX对应的VALUE(仅限JSONARRAY类型)同上

六. 关于操作符

  • 对象都可以用经典的get/set方式操作,也可以用函数操作
//get   以下两行代码效果等同
JsonVariant value = object["key"];
JsonVariant value = object.getMember("key");
 
//set  以下两行代码效果等同
object["key"] = "value";
object.getOrCreateMember("key").set("value");
 
StaticJsonDocument<256> doc;
JsonObject object = doc.to<JsonObject>();
object["hello"] = "world";
const char* world = object["hello"];

七. 编码JSON字符串示例:

#include <ArduinoJson.h>
 
void setup() {
  Serial.begin(115200);
  // 200 是大小 如果这个Json对象更加复杂,那么就需要根据需要去增加这个值.
  StaticJsonDocument<200> doc;
 
  // StaticJsonDocument 在栈区分配内存   它也可以被 DynamicJsonDocument(内存在堆区分配) 代替
  // DynamicJsonDocument  doc(200);
 
  //添加键值对
  doc["sensor"] = "gps";
  doc["time"] = 1351824120;
 
  // 添加数组.
  JsonArray data = doc.createNestedArray("data");
  data.add(48.756080);
  data.add(2.302038);
 
//串口打印结果
  serializeJson(doc, Serial);
}
 
void loop() {
}

八. 解码JSON字符串示例:

#include <Arduino.h>
#include "ArduinoJson.h"
 
String jsonStr = "{\"results\":[{\"location\":{\"id\":\"WW7MBNP039PE\",\"name\":\"泰安\",\"country\":\"CN\",\"path\":\"泰安,泰安,山东,中国\",\"timezone\":\"Asia/Shanghai\",\"timezone_offset\":\"+08:00\"},\"now\":{\"text\":\"晴\",\"code\":\"0\",\"temperature\":\"28\"},\"last_update\":\"2020-09-09T10:09:00+08:00\"}]}";
DynamicJsonDocument doc(512);
 
void setup()
{
  Serial.begin(115200);
  delay(3000);
}
void loop()
{
  //解析JSON字符串
  Serial.println("从jsonStr解码成的DynamicJsonDocument对象doc:");
  deserializeJson(doc, jsonStr);
  serializeJson(doc, Serial);
  Serial.println("从doc对象转换成的JsonObject类型对象root:");
  JsonObject root = doc.as<JsonObject>();
  serializeJson(root, Serial);
  Serial.println();
  Serial.println(doc.memoryUsage());
  Serial.println(measureJson(doc));
  Serial.println(measureJsonPretty(doc));
  Serial.println("root里有一个子JsonArray对象 results:");
  JsonArray results = root["results"];
  serializeJson(results, Serial);
  Serial.println();
  //JsonArray类型的数组results里面只有一个元素: JsonObject对象results[0],
  //该元素有三个子对象 location, now, last_update
  //location
  Serial.println("JsonObject对象 results[0]中的子JsonObject对象location:");
  JsonObject location = results[0]["location"];
  serializeJson(location, Serial);
  Serial.println();
  Serial.println("从JsonObject对象location中取出id");
  const char *id = location["id"];
  Serial.println(id);
  Serial.println("从JsonObject对象location中取出name");
  const char *name = location["name"];
  Serial.println(name);
  Serial.println("从JsonObject对象location中取出country");
  const char *country = location["country"];
  Serial.println(country);
  Serial.println("从JsonObject对象location中取出path");
  const char *path = location["path"];
  Serial.println(path);
  Serial.println("从JsonObject对象location中取出timezone");
  const char *timezone = location["timezone"];
  Serial.println(timezone);
  Serial.println("从JsonObject对象location中取出timezone_offset");
  const char *timezone_offset = location["timezone_offset"];
  Serial.println(timezone_offset);
  //now
  Serial.println("JsonObject对象 results[0]中的子JsonObject对象now(为了避免和timer中的now重名,把它叫做now1):");
  JsonObject now1 = results[0]["now"];
  serializeJson(now1, Serial);
  Serial.println("从JsonObject对象now1中取出text");
  const char *text = now1["text"];
  Serial.println(text);
  Serial.println("从JsonObject对象now1中取出code");
  const char *code = now1["code"];
  Serial.println(code);
  Serial.println("从JsonObject对象now1中取出temperature");
  const char *temperature = now1["temperature"];
  Serial.println(temperature);
  //last_update
  const char *last_update = results[0].getMember("last_update");
  Serial.println("last_update:");
  Serial.println(last_update);
  Serial.println();
  delay(10000);
}
  • 2
    点赞
  • 21
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值