当前位置:首页 » 操作系统 » linuxcjson

linuxcjson

发布时间: 2023-05-29 04:34:24

A. arm-linux-gcc不认识WI,-Bdynamic

换版本。你这个gcc的版本不支持。

B. linux 下c程序哪一个json库比较好用

推荐使用 cJSON, 很精巧的json解析库,只有一个头弊氏文件和租碧散一个源文件, 代码精炼,只有500多行。库中附带使用案慧迅例

C. linux能够识别的程序代码是什么

1、读取文件全部内容
#include <stdio.h>
#include <stdlib.h>

int main(int argc, char* argv[])
{
char ch;
FILE* fp;
unsigned long int count = 0;
char buf[1025] = {0};

// 这里要求我们在输入两个参数,第一个为 exe 路径,第二个为 文件名
// 如 file_test.exe test.txt
if (argc != 2)
{
printf("Usage: %s filename\n", argv[0]);
exit(EXIT_FAILURE);
}
if ((fp = fopen(argv[1], "r")) == NULL)
{
// 如果文件打开失败(通常是文件不存在),则结束程序
printf("Can't open %s\n", argv[1]);
exit(EXIT_FAILURE);
}
while ((ch = getc(fp)) != EOF && count < 1024)
{
// 显示文本内容并计数
buf[count] = ch;
count++;
}
fclose(fp);
printf("%s\n", buf);
printf("丛哪File %s has %lu characters\n", argv[1], count);

return 0;
}

2、cJSON解析字符串
编译选项要加 -lm

示例源串

{
"server": {
"nodes": [{
"ip": "10.76.76.190",
"port": 6379
}, {
"ip": "10.76.76.191",
"port": 6380
}, {
"ip": "10.76.76.192",
"port": 6381
}],
"password": "admin"
},
"isssl": true
}
登散逗录后复制

示例代码(每一行记得判空,编译时加-lm选项)

#include <stdio.h>
#include "cJSON.h"
int main(){

char c[] = "{\"server\":{\"nodes\":[{\"ip\":\"10.76.76.190\",\"port\":6379},{\"ip\":\"10.76.76.191\",\"port\":6380},{\"ip\":\"10.76.76.192\",\"port\":6381}],\"password\":\冲郑卖"admin\"},\"isssl\":true}";

cJSON* root = cJSON_Parse(c);
cJSON* json_server = cJSON_GetObjectItem(root, "server");
cJSON* json_isssl = cJSON_GetObjectItem(root, "isssl");
cJSON* json_password = cJSON_GetObjectItem(json_server, "password");
cJSON* json_nodes = cJSON_GetObjectItem(json_server, "nodes");

int i = 0;
for (; i != cJSON_GetArraySize(json_nodes); ++i) {
cJSON* each = cJSON_GetArrayItem(json_nodes, i);
cJSON* json_ip = cJSON_GetObjectItem(each, "ip");
cJSON* json_port = cJSON_GetObjectItem(each, "port");
printf("ip %s\n", json_ip->valuestring);
printf("port %d\n", json_port->valueint);
}

printf("password %s\n", json_password->valuestring);
printf("is ssl %s\n", json_isssl->valueint ? "true":"false");
cJSON_Delete(root);
}

3、curl拿到回传的数据
编译选项要加 -lcurl

头部选项参考

https://curl.se/libcurl/c/curl_easy_setopt.html
#include <stdio.h>
#include <stdlib.h>
#include <string.h>
#include <curl/curl.h>

struct string {
char* ptr;
size_t len;
};

void init_string(struct string* s) {
s->len = 0;
s->ptr = malloc(s->len + 1);
if (s->ptr == NULL) {
fprintf(stderr, "malloc() failed\n");
exit(EXIT_FAILURE);
}
s->ptr[0] = '\0';
}

size_t writefunc(void* ptr, size_t size, size_t nmemb, struct string* s) {
size_t new_len = s->len + size * nmemb;
s->ptr = realloc(s->ptr, new_len + 1);
if (s->ptr == NULL) {
fprintf(stderr, "realloc() failed\n");
exit(EXIT_FAILURE);
}
memcpy(s->ptr + s->len, ptr, size * nmemb);
s->ptr[new_len] = '\0';
s->len = new_len;

return size * nmemb;
}

int main(void) {
CURL* curl;
CURLcode res;

curl = curl_easy_init();
if(curl) {
struct string s;
init_string(&s);

curl_easy_setopt(curl, CURLOPT_URL, "https://www..com");
curl_easy_setopt(curl, CURLOPT_POSTFIELDS, "test");
curl_easy_setopt(curl, CURLOPT_WRITEFUNCTION, writefunc);
curl_easy_setopt(curl, CURLOPT_WRITEDATA, &s);
res = curl_easy_perform(curl);

printf("打印数据:\n%s", s.ptr);
free(s.ptr);

/* always cleanup */
curl_easy_cleanup(curl);
}
return 0;
}

4、获取随机数
#include <stdio.h>

int main(int argc, char* argv[]){

srand((int)time(0));

//打印 32位 test 随机数,并用16进制表示
int test2 = rand();
printf("%lx \n", test2);

// 打印 64位 test 随机数,并用16进制表示, 016代表不足16位的部分,补零,llx代表打印64位的16进制数
unsigned long long test = ((unsigned long long)rand() << 32) + rand();
printf("%016llx \n", test);

return 0;
}

5、定义按位的结构体
总结,按照位定义结构体,一定要都按照位定义,不然会出现意想不到的错误,而且一定要定义无符号的

#include <stdio.h>
#pragma pack (1)

struct test1 {

unsigned char cloud_id:3;
unsigned char vendor_id:4;
unsigned short machine_id;
unsigned long long current_time:41;

};

struct test2 {

unsigned char cloud_id:3;
unsigned char vendor_id:4;
unsigned short machine_id:16;
unsigned long long current_time:41;

};

int main(int argc, char* argv[]){

printf("test1 大小 : %d \n", sizeof(struct test1));
printf("test2 大小 : %d \n", sizeof(struct test2));

return 0;
}

6、按位打印01字节码
#include <stdio.h>
// 修改type后面的类型,可以查看各种数的字节码
#define type unsigned int

void print_bin(type num)
{
int len = sizeof(type);
int n = 8;
int i, j, k;
unsigned char *p = (unsigned char*)&num + len -1;

for (i = 0; i < len; i++) //处理len个字节
{
j = *(p - i); //取每个字节的首地址
for ( k = 7; k >= 0; k--) //处理每个字节的8个位
{
if (j & (1 << k))
printf("1");
else
printf("0");
}
printf(" ");
}
printf("\r\n");
}

int main(int argc, char* argv[]){

type a = 100;
print_bin(a);

return 0;
}
登录后复制

7、打印16进制字节码
#include<stdio.h>
typedef unsigned char uint8;
#define HEXDUMP_LINE_LENGTH 16
void hex_mp(uint8* data, int length)
{
uint8* p = data;
int i, line, offset = 0;

while (offset < length)
{
printf("%04x ", offset);

line = length - offset;

if (line > HEXDUMP_LINE_LENGTH)
line = HEXDUMP_LINE_LENGTH;

for (i = 0; i < line; i++)
printf("%02x ", p[i]);

for (; i < HEXDUMP_LINE_LENGTH; i++)
printf(" ");

for (i = 0; i < line; i++)
printf("%c", (p[i] >= 0x20 && p[i] < 0x7F) ? p[i] : '.');

printf("\n");

offset += line;
p += line;
}
}

8、打印字节码简易版
#include <stdio.h>
#include <string.h>
#include <stdlib.h>
void main() {
unsigned char Buf[] = "123456";
unsigned int len = strlen(Buf);
char* Buf1 = (char*)malloc(len * 3 + 1);
int i = 0, k = 0;
for (; i < len * 3; i += 3, k++)
snprintf(&Buf1[i], 4, "%02x ", Buf[k]);
printf(Buf1);
free(Buf1);
}

9、逐级创建文件夹
#include <stdio.h>
#include <stdlib.h>
#include <string.h>
#include <sys/stat.h>
#include <sys/types.h>
int mkdir_recursively(char* dir) {
if (NULL == dir)
return 1;

size_t len = strlen(dir);
char* str = malloc(len + 1);

if (NULL == str)
return 1;

strcpy(str, dir);
int i = 0;
for (i = 0; i < len; i++) {
if (str[i] == '/') {
if (i == 0)
continue;
str[i] = '\0';
if (access(str, 0) != 0) {
if (mkdir(str, S_IRWXU | S_IRGRP | S_IXGRP | S_IROTH | S_IXOTH)) {
free(str);
return 1;
}
}
str[i] = '/';
}
}

if (len > 0 && access(str, 0) != 0) {
if (mkdir(str, S_IRWXU | S_IRGRP | S_IXGRP | S_IROTH | S_IXOTH)) {
free(str);
return 1;
}
}

free(str);
return 0;
}
int main() {
mkdir_recursively("/home/test/abc/edf")

D. java怎么实现JSON打包UDP

java实现JSON打包UDP cJSON支持在C程序中创建和解析JSON数据,其提供多种方法供C程序使用,最直接的是将cJSON.c和cJSON.h加入到C工程中

(1) QJsonObject用于在Qt中创建JSON对象

(2)数据传输通过UDP运行

E. “生万物”的鸿蒙来了!华为布局AIoT最重要的版图

《庄子·逍遥游》中有这样的描述:“北冥有鱼,其名为鲲。鲲之大,不知其几千里也。化而为鸟,其名为鹏。鹏之背,不知其几千里也;怒而飞,其翼若垂天之云。“古人常用鲲鹏之志形容志向远大。


鸿蒙系统正式面世

6月2日晚8点,备受关注的华为鸿蒙操作系统正式面向消费者发布,它将正式搭载到手机、平板电脑,甚至豆浆机、烤箱等家电设备上。


华为鸿蒙操作系统的横空出世,是具有里程碑意义重大的“世纪之战”,华为鸿蒙挑战的是手机操作系统谷歌安卓、苹果IOS,以及电脑操作系统windows和开源linux操作系统、苹果MAC OS操作系统。

据悉,目前的操作系统市场,安卓占据了全球市场份额的68.63%,苹果占据了30.99%。华为鸿蒙操作系统的出现,有可能打破这两家独大的状况。

到底什么是鸿蒙系统?

发布会上,华为消费者业务软件部总裁王成录用一句话概括了鸿蒙操作系统(以下简称“鸿蒙”)给当前的手机系统带来的变化:

“在智能手机的时代,让消费者有机会根据自己的需要来组装软件(指APP)。那么,鸿蒙相对于今天的操作系统,又有一个飞跃,让消费者可以根据自己的需要来组装不同的硬件。”

按照华为的规划,今年底搭载鸿蒙OS的终端设备将超过3亿台,其中1亿台为第三方合作伙伴的终端设备。

华为轮值CEO徐直军表示,目前鸿蒙操作系统生态已经发展了1000多个智能硬件合作伙伴,50多个模组和芯片解决方案合作伙伴,包括家居、出行、教育、办公、运动 健康 、政企、影音 娱乐 等多个领域的合作伙伴。

实际上,鸿蒙操作系统打通了消费互联网和产业互联网。

鸿蒙赋能各大场景万物互联

据徐直军介绍,华为鸿蒙操作系统在2021年的举措主要包括:鸿蒙官网、论坛、社区、公众号等全面上线;源代码全面开源,覆盖手机、平板、车机、智慧屏及各类IoT设备;开放鸿蒙培训平台,标准课程,构建统一的人才认证体系,推动鸿蒙技术能力走进校园等。

2020年中国智能家居市场规模将突破2400亿,2020年全球智能家居市场平均渗透率将超过60%。未来三年将是智能家居行业快速发展期。相比开发周期较长的家电行业,鸿蒙OS 对于产业赋能效果显着。

通过物联网技术,家中的智能化的家用电器可以紧密相连,通过智能运作便可以实现远程控制。智能家居不仅具有传统的居住功能,兼备建筑、网络通信、信息家电、设备自动化,提供全方位的信息交互功能,甚至为各种能源费用节约资金。

这些智能化的设备、家用电器在鸿蒙系统发布后,将会进一步推进家居智能化的到来。家居智能化最重要的一环,就是互联网技术与家用设备的结合。

随着互联网头部企业的技术发展,大数据技术、云计算技术人才的不断增多,家居智能化取得了长足进步。鸿蒙问世将搭载大数据技术和发展的前沿应用趋势,以小川汇集大海之势,融合场景,连接设备,努力成为新一代操作系统的新贵。

如何实现更好的智能体验?

在全场景智慧生活应用中设备联结、控制复杂,体验感分割等问题,面对如此庞大的终端设备群,鸿蒙系统该如何实现更好的智能体验?

1、全系统覆盖

鸿蒙系统使用分布式框架和原子化服务将各设备用软总线联结,达成全系统覆盖,保证用户有机会根据自身需求随意组装,实现模块化定制加持。并且,硬件弹性大,从128k--4G以上,鸿蒙系统都可以使用。

2、多设备融合为“超级终端”

鸿蒙系统采用“软时钟同步”和“无限传输干扰”来解决音画同步的技术难点。PC系统安装鸿蒙分布式插件后,手机文件就相当于新盘符,便于PC端调用手机内容及材料。

使用超级终端统一入口来操控设备模组,提升设备间敏捷度,完成与手机联结的所有第三方设备状态的实时查看和操控。

另外,我国现阶段家电设备自动化程度持续提高,但由于设备与设备间的碎片化分布使之无法充分发挥性能优势。鸿蒙系统将打破消费者智能使用率不到5%的现状,增强设备黏合度,打造全生态模式。

3、应用跨设备流转

“万能卡片”将成为鸿蒙生态设备之间统一交互的载体和语言,卡片到哪里,服务转到哪里,真正打破应用间的硬件约束。所有鸿蒙设备间都将通过“万能卡片”进行有效流转,所有卡片信息全部显示在服务中心用户无需再次安装,被分享手机无需事先安装APP,便捷实现信息互联。

华为业务软件部总裁王成录博士表示,鸿蒙OS就是要让消费者在操控多种设备时像操控单设备一样简单。

能否“突围”几乎定局的市场份额?

此前,小米和Google都曾推送新操作系统。小米Vela主要布局在AIoT生态圈可穿戴设备及智能家居场景布局上,与鸿蒙系统全设备万物互联并不完全相同。但Google Fuchsia OS,同样是囊括手机、PC在内的万物互联定位。在这样的环境下,鸿蒙系统具备哪些逆风破局的优势?

首先,鸿蒙系统开源的liteos内核已趋向稳定。liteos内核是由华为OS团队专门维护其核心组件,包括ota、shell、fs、usip、oc、crc、cJSON等组件。这些组件可以为开发者提供简单接口实现孔中升级、shell等功能,帮助开发者更轻松的开发物联网设备。自2015年起,它就已广泛应用到摄像头、手机指纹传感器等设备中,未来将作为华为解决方案一起来开拓市场份额。

其次,华为海量终端用户也将在鸿蒙系统万物互联中起到关键性作用。在发布会上,华为发布了watch3、HUAWEI MatePad Pro、HUAWEI MateView、HUAWEI FreeBuds4无线耳机等新品。并宣布自6月2日起,Mate30、40系列都会同步进行ota升级,nova6、7等老款机型也将在第三季度全面进行升级。由此可见,华为的硬件优势都将为华为AIoT生态化建设提供关键性扶持作用。

鸿蒙OS,现阶段只是生态建设的开始,下一步将需要硬件厂商、应用厂商、集成商的联合支持。

总结:3亿和16%的生死突围

要把生态链发展到什么程度,鸿蒙才算是存活了下来?

华为消费者业务AI与智慧全场景业务部副总裁杨海松给出了一个数字——16%。

“对于操作系统这类底层平台而言,软件使用量、市场占有率是它能否活下来、能否成功的核心因素,而16%的市占率则是一个生死线。”杨海松说。

为了迈过这16%市占率的生死线,华为在2021年的目标:搭载鸿蒙的设备数量需达到3亿更显得任重而道远。

目前来看,暂无其他手机厂商伸出援手,生态链也尚未完善,鸿蒙恐怕还有很长一段道路需要走。

F. 有哪些 C++ 的 JSON 库比较好

我现在用的是cJSON这个JSON库,在github上可以下载到,是开源的,Windows和Linux系统开发都可以用。而且是最轻量级的JSON库,下载下来之后再解压,只需要将里面的cJSON.c和cJSON.h这两个文件复制到你的项目(源码)目录就可以了(需要调用cJSON的那个代码文件要加上一句#include "cJSON.h")。使用起来也超简单,通过阅读cJSON.h中的函数注释和github上面的说明你就会知道怎么用。

G. linux 下c程序哪一个json库比较好用

推荐使用
cJSON,
很扰洞精巧的json解析库,只有一旁乱个头文件和一个源文运李档件,
代码精炼,只有500多行。库中附带使用案例

热点内容
支付宝付款码怎么设置密码 发布:2024-05-05 01:27:36 浏览:877
qtp录制的脚本 发布:2024-05-05 01:14:04 浏览:366
如何安装卡罗拉安卓系统 发布:2024-05-05 01:09:00 浏览:984
sql创建表查询表 发布:2024-05-05 01:00:12 浏览:798
食色抖音上传 发布:2024-05-05 00:55:56 浏览:657
java图片下载 发布:2024-05-05 00:50:45 浏览:597
唱吧如何上传伴奏 发布:2024-05-05 00:49:04 浏览:444
什么配置单反拍视频最好 发布:2024-05-05 00:30:56 浏览:478
sql敏感 发布:2024-05-05 00:28:20 浏览:62
android工程师笔试 发布:2024-05-05 00:10:52 浏览:948