深入探索Linux下的ON包,实现高效数据交换 (linux 下的json包)

在当今互联网时代,数据交换已经变得越来越频繁且重要。为了满足这种需求,数据格式逐渐标准化,其中一种极为广泛应用的格式就是ON。ON被广泛应用于Web应用程序和移动应用程序中,其主要优点是简单易用、轻量级、易于阅读和编写等。本文将深入探索在Linux系统下的ON包,以实现高效的数据交换。

ON是什么

ON(JavaScript Object Notation)是一种轻量级的数据交换格式。它基于JavaScript语言,但已经成为一种通用的数据格式,可用于各种编程语言。ON格式的数据可以非常容易地读取和解析,这使得它成为应用程序中数据传输的首选格式。

ON的基本结构由两种数据类型组成:

1. 键值对:一个字符串表示键,后面跟着一个冒号,然后是一个值。键值对用逗号分隔。例如:

“`

{“name”: “John”, “age”: 30}

“`

2. 值:可以是一个字符串、数字、对象、数组、布尔值或null。例如:

“`

“name”: “John”

“`

ON的优点

相较于其他数据格式,ON有以下几个优点:

1. 高效:ON数据格式的数据体积很小,传输速度快。

2. 易读写:ON数据格式的字符串格式化很容易,易于读写。

3. 易解析:ON数据格式的解析起来是非常容易的。

4. 跨平台支持:ON可以被不同操作系统和编程语言支持。

Linux下的ON包

在Linux系统下,C语言是使用最广泛的编程语言之一。因此,使用C语言编写ON处理程序是非常可取的。 在下面的介绍中,我们将深入探索四个流行的C语言ON包:Jansson、json-c、cON和yajl。

1. Jansson

Jansson是一个C语言编写的ON库,具有解析和构建ON文档的功能。它在性能和易用性方面表现出色,被广泛用于各种应用程序中。Jansson还支持对ON文档进行合并、比较和验证等操作。

以下是使用Jansson解析ON文档的示例代码:

“`

#include

int mn()

{

const char *json_string = “{\”name\”: \”John\”, \”age\”: 30}”;

json_t *root;

json_error_t error;

root = json_loads(json_string, 0, &error);

if (root) {

json_t *name, *age;

const char *name_str;

int age_int;

name = json_object_get(root, “name”);

name_str = json_string_value(name);

age = json_object_get(root, “age”);

age_int = json_integer_value(age);

printf(“Name: %s, Age: %d\n”, name_str, age_int);

} else {

fprintf(stderr, “error: on line %d: %s\n”, error.line, error.text);

return 1;

}

json_decref(root);

return 0;

}

“`

2. json-c

json-c是另一个C语言编写的ON库。它跟Jansson非常相似,也具有解析和构建ON文档的功能。json-c支持ON文档的基本操作,如添加、删除和修改,以及ON文档的打印及格式化输出。

以下是使用json-c解析ON文档的示例代码:

“`

#include

#include

#include

int mn()

{

const char *json_string = “{\”name\”: \”John\”, \”age\”: 30}”;

struct json_object *root = json_tokener_parse(json_string);

struct json_object *name, *age;

const char *name_str;

int age_int;

json_object_object_get_ex(root, “name”, &name);

name_str = json_object_get_string(name);

json_object_object_get_ex(root, “age”, &age);

age_int = json_object_get_int(age);

printf(“Name: %s, Age: %d\n”, name_str, age_int);

json_object_put(root);

return 0;

}

“`

3. cON

cON是一个轻量、快速的C语言ON库。它与Jansson和json-c相比,具有更小的内存占用和更快的解析速度。由于它非常容易使用,因此cON被广泛应用于各种嵌入式系统。

以下是使用cON解析ON文档的示例代码:

“`

#include

#include

#include “cON.h”

int mn()

{

const char *json_string = “{\”name\”: \”John\”, \”age\”: 30}”;

cON *root = cON_Parse(json_string);

if (root) {

cON *name, *age;

const char *name_str;

int age_int;

name = cON_GetObjectItem(root, “name”);

name_str = name->valuestring;

age = cON_GetObjectItem(root, “age”);

age_int = age->valueint;

printf(“Name: %s, Age: %d\n”, name_str, age_int);

} else {

printf(“Error before: [%s]\n”, cON_GetErrorPtr());

return 1;

}

cON_Delete(root);

return 0;

}

“`

4. yajl

yajl(Yet Another ON Library)是另一个流行的C语言ON库。它具有非常好的性能和灵活性,支持流式解析和生成ON。yajl的API使用起来非常方便,但比其他ON库稍微复杂一些。

以下是使用yajl解析ON文档的示例代码:

“`

#include

#include

#include

#include

#include

static int print_name(void *ctx, const unsigned char *name, size_t name_len)

{

printf(“Name: %.*s, “, (int)name_len, name);

return 1;

}

static int print_age(void *ctx, long long age)

{

printf(“Age: %lld\n”, age);

return 1;

}

static yajl_callbacks callbacks = {

.yajl_string = print_name,

.yajl_number = print_age,

};

int mn()

{

const char *json_string = “{\”name\”: \”John\”, \”age\”: 30}”;

yajl_handle handle;

yajl_parser_config cfg = { 0, 0 };

yajl_status status;

handle = yajl_alloc(&callbacks, &cfg, NULL);

status = yajl_parse(handle, (const unsigned char *)json_string, strlen(json_string));

if (status != yajl_status_ok) {

printf(“Error: %s\n”, yajl_get_error(handle, 1, (const unsigned char *)json_string, strlen(json_string)));

return 1;

}

yajl_free(handle);

return 0;

}

“`

结论

相关问题拓展阅读:

Docker配置文件daemon.json解析

Docker Engine V1.12 之后版本,用户可以自行创建 daemon.json 文件对 Docker Engine 进行配置和调整。要点如下:

该 –config-file 选项允许您以ON格式为守护程序设置任何配置选项。此文件使用与键相同的标志名称,但允许多个条目的标志除外,它使用多个标志名称,例如, labels 用于 label 标志。

配置文件中设置的选项不得与通过flags设置的选项冲突。如果文件和标志之间的选项重复,则docker守护程序无法启动,无论掘芹握其值如何。我们这样做是为了避免静默忽略配置重新加载中引入的更改。例如,如果在配置文件中设置守护程序标签并且还通过 –label 标志设置守护程序标签,则守护程序无首知法启动。守护程序启动时将忽略文件中不存在的选项。

Linux上配置文件的默认位置是 /etc/docker/daemon.json 。该 –config-file 标志可用于指判庆定非默认位置。

修改配置文件之后需要重启docker生效

systemctl restart docker.service

参考资料:

Daemon configuration file

daemon.json的作用

linux 下的json包的介绍就聊到这里吧,感谢你花时间阅读本站内容,更多关于linux 下的json包,深入探索Linux下的ON包,实现高效数据交换,Docker配置文件daemon.json解析的信息别忘了在本站进行查找喔。


数据运维技术 » 深入探索Linux下的ON包,实现高效数据交换 (linux 下的json包)