学习Git与JSON_git学习周报-程序员宅基地

技术标签: 学习  

目录

1.Git

GIt操作及指令

远程仓

2.共用体

3.linux内核链表

4.三方库的移植

5.JSON

示例

JSON基本操作

cJson的使用


1.Git

git是一款分布式版本控制软件,他的作者是Linux创始人linus,所以它也是开源的。他的作用有两个,一是版本的管理或者控制,另外一个就是多人协作。除了git还有svn、cvs这样的版本控制软件,它们的区别在于一个是分布式一个是集中式的。

集成式的特点:所有的版本库都存在中央服务器,本地备份动作必须依赖中央服务器,如果一旦服务器挂掉,或者网络状况不好,没法提交版本。

分布式的特点:每一台客户端都有完整的版本备份,所有的版本提交不需要依赖中央服务器,只有多人协作时候,需要用服务器交换一下版本库。

git的优点就在于它的版本管理速度快,容灾行更高,可以不依赖网络,所以越来越多的公司更愿意去使用git。

工作区:相当于工作的文件夹

版本库:Git备份的位置

远程仓:远程的服务器

GIt操作及指令

配置个人信息

git config --global user.name "name"

git config --global user.email "[email protected]"

中文显示

git config --global core.quotepath false

个人配置信息

git config -l

初始化仓库

git init

提交工作内容版本库

git add <文件名>:*代表所有的文件--- git add *
git commit -m "<提交的内容>"

查看版本记录

git log

查看工作区的状态

git status

丢掉工作区的内容

git checkout <文件名>

版本回退

git log
git reset --hard <版本ID>

版本前进

git reflog :显示引用记录,引用记录包括所有的提交信息
git reset --hard <版本ID>

远程仓

远程仓使用的是中国的码云,里面有很多开源的代码,方便学习交流,项目代码可以放在上面托管。

2.共用体

结构体和共用体的区别在于:结构体的各个成员会占用不同的内存,互相之间没有影响;而共用体的所有成员占用同一段内存,修改一个成员会影响其余所有成员。结构体占用的内存大于等于所有成员占用的内存的总和(成员之间可能会存在缝隙),共用体占用的内存等于最长的成员占用的内存。共用体使用了内存覆盖技术,同一时刻只能保存一个成员的值,如果对新的成员赋值,就会把原来成员的值覆盖掉。

结构体字节对齐的原则:

1) 结构体变量的首地址能够被其最宽基本类型成员的大小所整除;

2) 结构体每个成员相对结构体首地址的偏移量都是成员大小的整数倍,如有需要编译器会在成员之间加上填充字节;

3) 结构体的总大小为结构体最宽基本类型成员大小的整数倍,如有需要编译器会在最末一个成员之后加上填充字节。

总结:首地址对齐(按最大)、总大小对齐(按最大)、成员对齐(按成员类型)

3.linux内核链表

老师发的链表非常好用,但有些具体功能实现还是不理解,现在还单纯停留在使用层面,通过不断地学习总结提高自己的能力,然后去研究研究源码。

4.三方库的移植

步骤:

  1. 从官方网站或者gitub等平台获取源码。
  2. 解压源码并进入目录。
  3. 在源码目录新建work目录以便后续的安装。
  4. 配置编译选项。                                                                                                                 configure是一个可执行的配置脚本(用来生成Makefile)                                                             --host:指定编译器                                                                                                                   --prefix:指定安装目录(如果不指定此选项,那么默认安装到系统路径)                           ./configure --prefix=$PWD/work)
  5. 如果是交叉编译,给ARM板用,配置选项如下                                                               ./configure --host=arm-linux- --prefix=$PWD/work
  6. 编译:make
  7. 安装 make install,这个install它是Makefile中的一个目标,会自动把生成的内容拷贝到上面指定的文件夹中。
  8. 安装成功以后,work目录会有:头文件、库文件、可执行程序

5.JSON

JSON是JavaScript Object Notation的缩写,它是一种数据交换格式。JSON实际上是JavaScript的一个子集。

数据类型:

  • number:和JavaScript的number完全一致;相当于C中的int类型
  • boolean:就是JavaScript的true或false;相当于c++中的bool类型
  • string:就是JavaScript的string;相当于c++的string类型
  • null:就是JavaScript的null;相当于C的NULL类型
  • array:就是JavaScript的Array表示方式;相当于C的数组
  • object:就是JavaScript的{ ... }表示方式。相当于C++的类或者C的结构体

示例

{
  "name": "小明",
  "age": 14,
  "gender": true,
  "height": 1.65,
  "grade": null,
  "middle-school": "\"W3C\" Middle School",
  "skills": [
    "JavaScript",
    "Java",
    "Python",
    "Lisp"
  ]
}
  • json以大括号起始和结尾
  • 内容都是以键值对的形式存在
  • 所有的键都是字符串
  • 值的类型不一定,属于JavaScript 的基本数据类型
  • 每个键值对以,分割
  • 最后一个键值对不加逗号

JSON基本操作

json序列化和反序列化

序列化是将信息转为json格式的字符串;反序列化就是从json字符串中取出信息;

cJson的使用

//从 给定的json字符串中得到cjson对象
extern cJSON *cJSON_Parse(const char *value);
//从cjson对象中获取有格式的json对象
extern char  *cJSON_Print(cJSON *item);
//从cjson对象中获取无格式的json对象
extern char  *cJSON_PrintUnformatted(cJSON *item);
//删除cjson对象,释放链表占用的内存空间 
extern void   cJSON_Delete(cJSON *c);
//获取cjson对象数组成员的个数
extern int    cJSON_GetArraySize(cJSON *array);
//根据下标获取cjosn对象数组中的对象
extern cJSON *cJSON_GetArrayItem(cJSON *array,int item);
//根据键获取对应的值(cjson对象)
extern cJSON *cJSON_GetObjectItem(cJSON *object,const char *string);
//获取错误字符串
extern const char *cJSON_GetErrorPtr(void);

在解析json时,有类似分层的思想,就像我们剥洋葱,每个大括号就代表着一层,每一层都对应着对象,再去访问对象中的数据或者再去剥洋葱那样剥去一层。

反序列化:

#include <stdio.h>
#include <stdlib.h>
#include "list.h"
#include "cJSON.h"

#define SIZE_T 512
#define BOOL int

union val_t {
    int val_int;
    BOOL val_bool;
    float val_float;
};
struct data
{
    int key;
    int type;
    union val_t val;
    struct list_head list;
};

int main(int argc, char const *argv[])
{
    //**********解析json*********
    struct data *node = NULL;
    struct list_head head;
    FILE *fp = fopen("./json.txt", "r");
    char *buf[SIZE_T] = {0};
    int ret = fread(buf, sizeof(buf), 1, fp);
    if (ret < 0)
    {
        printf("fread err\n");
        return -1;
    }
    //   printf("%s\n", jsonStr);
    cJSON *root = NULL;
    cJSON *item = NULL;
    cJSON *arr = NULL;
    root = cJSON_Parse(jsonStr);
    if (root == NULL)
    {
        printf("error before: [%s]\n", cJSON_GetErrorPtr());
        return -1;
    }
    INIT_LIST_HEAD(&head);

    item = cJSON_GetObjectItem(root, "ver");
    printf("%s\n", cJSON_Print(item));

    item = cJSON_GetObjectItem(root, "cloud");
    cJSON *passwd = cJSON_GetObjectItem(item, "password");
    printf("%s\n", cJSON_Print(passwd));
    cJSON *mpasswd = cJSON_GetObjectItem(item, "mpassword");
    printf("%s\n", cJSON_Print(mpasswd));

    item = cJSON_GetObjectItem(root, "data");
    int num, i;
    num = cJSON_GetArraySize(item);
    for (i = 0; i < num; i++)
    {
        arr = cJSON_GetArrayItem(item, i);

        node = (struct data *)malloc(sizeof(struct data));
        cJSON *key = cJSON_GetObjectItem(arr, "key");
        node->key = key->valueint;

        cJSON *type = cJSON_GetObjectItem(arr, "type");
        node->type = type->valueint;

        printf("%d\n", type->valueint);
        cJSON *val = cJSON_GetObjectItem(arr, "val");

        switch (node->type)
        {
        case 1:
            node->val.val_bool = atoi(val->valuestring);
            printf("%d\n", node->val.val_bool);
            break;
        case 2:
            node->val.val_int = atoi(val->valuestring);
            printf("%d\n", node->val.val_int);
            break;
        case 3:
            node->val.val_float = atof(val->valuestring);
            printf("%f\n", node->val.val_float);
            break;
        }
        list_add(&node->list, &head);
    }

    struct list_head *pos;
    struct data *tmp;
    list_for_each(pos, &head)
    {
        tmp = list_entry(pos, struct data, list);
        switch (tmp->type)
        {
        case 1:
            printf("key = %d, type = %d, val = %d\n", tmp->key, tmp->type, tmp->val.val_bool);
            break;
        case 2:
            printf("key = %d, type = %d, val = %d\n", tmp->key, tmp->type, tmp->val.val_int);
            break;
        case 3:
            printf("key = %d, type = %d, val = %f\n", tmp->key, tmp->type, tmp->val.val_float);
            break;
        }
    }

    fclose(fp);
    free(jsonStr);
    cJSON_Delete(root);
    return 0;
}

版权声明:本文为博主原创文章,遵循 CC 4.0 BY-SA 版权协议,转载请附上原文出处链接和本声明。
本文链接:https://blog.csdn.net/ASCII11/article/details/125836380

智能推荐

攻防世界_难度8_happy_puzzle_攻防世界困难模式攻略图文-程序员宅基地

文章浏览阅读645次。这个肯定是末尾的IDAT了,因为IDAT必须要满了才会开始一下个IDAT,这个明显就是末尾的IDAT了。,对应下面的create_head()代码。,对应下面的create_tail()代码。不要考虑爆破,我已经试了一下,太多情况了。题目来源:UNCTF。_攻防世界困难模式攻略图文

达梦数据库的导出(备份)、导入_达梦数据库导入导出-程序员宅基地

文章浏览阅读2.9k次,点赞3次,收藏10次。偶尔会用到,记录、分享。1. 数据库导出1.1 切换到dmdba用户su - dmdba1.2 进入达梦数据库安装路径的bin目录,执行导库操作  导出语句:./dexp cwy_init/[email protected]:5236 file=cwy_init.dmp log=cwy_init_exp.log 注释:   cwy_init/init_123..._达梦数据库导入导出

js引入kindeditor富文本编辑器的使用_kindeditor.js-程序员宅基地

文章浏览阅读1.9k次。1. 在官网上下载KindEditor文件,可以删掉不需要要到的jsp,asp,asp.net和php文件夹。接着把文件夹放到项目文件目录下。2. 修改html文件,在页面引入js文件:<script type="text/javascript" src="./kindeditor/kindeditor-all.js"></script><script type="text/javascript" src="./kindeditor/lang/zh-CN.js"_kindeditor.js

STM32学习过程记录11——基于STM32G431CBU6硬件SPI+DMA的高效WS2812B控制方法-程序员宅基地

文章浏览阅读2.3k次,点赞6次,收藏14次。SPI的详情简介不必赘述。假设我们通过SPI发送0xAA,我们的数据线就会变为10101010,通过修改不同的内容,即可修改SPI中0和1的持续时间。比如0xF0即为前半周期为高电平,后半周期为低电平的状态。在SPI的通信模式中,CPHA配置会影响该实验,下图展示了不同采样位置的SPI时序图[1]。CPOL = 0,CPHA = 1:CLK空闲状态 = 低电平,数据在下降沿采样,并在上升沿移出CPOL = 0,CPHA = 0:CLK空闲状态 = 低电平,数据在上升沿采样,并在下降沿移出。_stm32g431cbu6

计算机网络-数据链路层_接收方收到链路层数据后,使用crc检验后,余数为0,说明链路层的传输时可靠传输-程序员宅基地

文章浏览阅读1.2k次,点赞2次,收藏8次。数据链路层习题自测问题1.数据链路(即逻辑链路)与链路(即物理链路)有何区别?“电路接通了”与”数据链路接通了”的区别何在?2.数据链路层中的链路控制包括哪些功能?试讨论数据链路层做成可靠的链路层有哪些优点和缺点。3.网络适配器的作用是什么?网络适配器工作在哪一层?4.数据链路层的三个基本问题(帧定界、透明传输和差错检测)为什么都必须加以解决?5.如果在数据链路层不进行帧定界,会发生什么问题?6.PPP协议的主要特点是什么?为什么PPP不使用帧的编号?PPP适用于什么情况?为什么PPP协议不_接收方收到链路层数据后,使用crc检验后,余数为0,说明链路层的传输时可靠传输

软件测试工程师移民加拿大_无证移民,未受过软件工程师的教育(第1部分)-程序员宅基地

文章浏览阅读587次。软件测试工程师移民加拿大 无证移民,未受过软件工程师的教育(第1部分) (Undocumented Immigrant With No Education to Software Engineer(Part 1))Before I start, I want you to please bear with me on the way I write, I have very little gen...

随便推点

Thinkpad X250 secure boot failed 启动失败问题解决_安装完系统提示secureboot failure-程序员宅基地

文章浏览阅读304次。Thinkpad X250笔记本电脑,装的是FreeBSD,进入BIOS修改虚拟化配置(其后可能是误设置了安全开机),保存退出后系统无法启动,显示:secure boot failed ,把自己惊出一身冷汗,因为这台笔记本刚好还没开始做备份.....根据错误提示,到bios里面去找相关配置,在Security里面找到了Secure Boot选项,发现果然被设置为Enabled,将其修改为Disabled ,再开机,终于正常启动了。_安装完系统提示secureboot failure

C++如何做字符串分割(5种方法)_c++ 字符串分割-程序员宅基地

文章浏览阅读10w+次,点赞93次,收藏352次。1、用strtok函数进行字符串分割原型: char *strtok(char *str, const char *delim);功能:分解字符串为一组字符串。参数说明:str为要分解的字符串,delim为分隔符字符串。返回值:从str开头开始的一个个被分割的串。当没有被分割的串时则返回NULL。其它:strtok函数线程不安全,可以使用strtok_r替代。示例://借助strtok实现split#include <string.h>#include <stdio.h&_c++ 字符串分割

2013第四届蓝桥杯 C/C++本科A组 真题答案解析_2013年第四届c a组蓝桥杯省赛真题解答-程序员宅基地

文章浏览阅读2.3k次。1 .高斯日记 大数学家高斯有个好习惯:无论如何都要记日记。他的日记有个与众不同的地方,他从不注明年月日,而是用一个整数代替,比如:4210后来人们知道,那个整数就是日期,它表示那一天是高斯出生后的第几天。这或许也是个好习惯,它时时刻刻提醒着主人:日子又过去一天,还有多少时光可以用于浪费呢?高斯出生于:1777年4月30日。在高斯发现的一个重要定理的日记_2013年第四届c a组蓝桥杯省赛真题解答

基于供需算法优化的核极限学习机(KELM)分类算法-程序员宅基地

文章浏览阅读851次,点赞17次,收藏22次。摘要:本文利用供需算法对核极限学习机(KELM)进行优化,并用于分类。

metasploitable2渗透测试_metasploitable2怎么进入-程序员宅基地

文章浏览阅读1.1k次。一、系统弱密码登录1、在kali上执行命令行telnet 192.168.26.1292、Login和password都输入msfadmin3、登录成功,进入系统4、测试如下:二、MySQL弱密码登录:1、在kali上执行mysql –h 192.168.26.129 –u root2、登录成功,进入MySQL系统3、测试效果:三、PostgreSQL弱密码登录1、在Kali上执行psql -h 192.168.26.129 –U post..._metasploitable2怎么进入

Python学习之路:从入门到精通的指南_python人工智能开发从入门到精通pdf-程序员宅基地

文章浏览阅读257次。本文将为初学者提供Python学习的详细指南,从Python的历史、基础语法和数据类型到面向对象编程、模块和库的使用。通过本文,您将能够掌握Python编程的核心概念,为今后的编程学习和实践打下坚实基础。_python人工智能开发从入门到精通pdf