zoukankan      html  css  js  c++  java
  • C语言 MAP

    最近需要在AWSIOT shadow添加设备状态,很明显JSON这种数据状态很明显每个状态都是Key-Value这种数据类型,很自然的想到使用MAP去实现这种状态。而代码又是跑在嵌入式设备中很明显是C语言,这里就带来一个问题,C语言原生是没有MAP实现的。作为生产环境使用,自己手搓轮子难免有考虑不周情况出现,这里就去github 摸代码,找个相对start高点,先测试一波。

    github 地址:https://github.com/petewarden/c_hashmap
    源码就两个文件 一个c 一个h,与其他lib相比这个lib, value值可以是动态类型。

    1 sample
    #include <stdlib.h>
    #include <stdio.h>
    #include <assert.h>
    #include <string.h>
    #include "hashmap.h"

    #define KEY_MAX_LENGTH (256)
    #define KEY_COUNT (1024*1024)

    typedef struct data_struct_s
    {
        char key_string[KEY_MAX_LENGTH];
        int type;
        int number;
    } data_struct_t;

    typedef struct DATASTRUCTSTR
    {
        char key_string[KEY_MAX_LENGTH];
        int type;
        char* str;
    } data_struct_str;

    typedef struct DATASTRUCTANY{
        char key_string[KEY_MAX_LENGTH];
        int type;
        any_t data;
    } data_struct_any_t;

    int iterate(any_t item, any_t data){
        printf("map key:%s\n", ((data_struct_any_t*)data)->key_string);
        printf("map type:%d\n",  ((data_struct_any_t*)data)->type);
        if( ((data_struct_any_t*)data)->type == 0){
            printf("map data:%d\n", ((data_struct_t *)data)->number);
        }else if(((data_struct_any_t*)data)->type== 1){
            printf("map data:%s\n", ((data_struct_str *)data)->str);
        }
        return MAP_OK;
    }

    int main(char* argv, int argc)
    {
        int index;
        int error;
        map_t mymap;
        char key_string[KEY_MAX_LENGTH];
        
        data_struct_any_t* anyt = malloc(sizeof(data_struct_any_t)); 
        data_struct_any_t* readitem = NULL; 

        mymap = hashmap_new();
        printf("\n--------put data start-------\n");
        data_struct_t* value;
        value = malloc(sizeof(data_struct_t));
        snprintf(value->key_string, KEY_MAX_LENGTH, "%s", "number");
        value->number = 123;
        value->type = 0;//自行定义 0为number
        error = hashmap_put(mymap, value->key_string, value);
        assert(error==MAP_OK);
        printf("key:number, value:%d\n", value->number);

        data_struct_str* str;
        str = malloc(sizeof(data_struct_str));
        snprintf(str->key_string, KEY_MAX_LENGTH, "%s", "str");
        str->str = (char*)malloc(sizeof(char)*100);
        strcpy(str->str,"helloworld");
        str->type = 1;//自行定义 1 str
        error = hashmap_put(mymap, str->key_string, str);
        assert(error==MAP_OK);
        printf("key:str, value:%s\n", str->str);
        
        printf("\n---------get data start--------\n");
        error = hashmap_get(mymap, "number", (void**)(&readitem));
        assert(error==MAP_OK);
        printf("number data:%d\n", ((data_struct_t *)readitem)->number);

        error = hashmap_get(mymap, "str", (void**)(&readitem));
        assert(error==MAP_OK);
        printf("str data:%s\n", ((data_struct_str *)readitem)->str);

        printf("\n---------iterate start--------\n");
        PFany IterateFunc = iterate;
        hashmap_iterate(mymap, IterateFunc, anyt);//这里可以第三个参数 传入指针从而 读到遍历时需要的某个值
        printf("\n----------remove start----------\n");
        error = hashmap_get(mymap, "number", (void**)(&readitem));
        assert(error==MAP_OK);
        error = hashmap_remove(mymap, readitem->key_string);
        assert(error==MAP_OK);
        free(readitem);
        printf("---------check remove result--------\n");
        anyt = NULL;
        hashmap_iterate(mymap, IterateFunc, anyt);
        hashmap_free(mymap);
        return 1;
    }

    输出定义了两个map值:
    一个key为number value为123
    一个key为str key为helloworld
    编译:
    gcc main.c hashmap.c -o test
    测试

    --------put data start-------
    key:number, value:123
    key:str, value:helloworld

    ---------get data start--------
    number data:123
    str data:helloworld

    ---------iterate start--------
    map key:number
    map type:0
    map data:123
    map key:str
    map type:1
    map data:helloworld

    ----------remove start----------
    ---------check remove result--------
    map key:str
    map type:1
    map data:helloworld

  • 相关阅读:
    ACM-ICPC 2018 徐州赛区网络预赛 D 杜教筛 前缀和
    51 Nod 1244 莫比乌斯函数前n项和
    20170914-构建之法:现代软件工程-阅读笔记
    结对-五子棋游戏-开发环境搭建过程
    结对-五子棋游戏-设计文档
    Git使用方法2.0
    团队-象棋游戏-团队信息
    Web开发技术——JQuery4(隐藏和显示、淡入和淡出、滑动)
    Web开发技术——JQuery3(事件)
    Web开发技术——JQuery2(语法和选择器)
  • 原文地址:https://www.cnblogs.com/lidabo/p/15566297.html
Copyright © 2011-2022 走看看