首页 > 其他分享 >glib 哈希调用

glib 哈希调用

时间:2023-04-06 13:45:18浏览次数:31  
标签:glib node 调用 hash key value 哈希 NULL data

glib: linux 编译调用

gcc main.c `pkg-config --libs --cflags glib-2.0` -o main

#include <stdio.h>
#include <glib.h>
#include <stdlib.h>
#include <string.h>

typedef struct _Node {
    char key[32];
    char value[32];
}Node;

static void displayhash(gpointer key, gpointer value, gpointer user_data) {
    printf("user_data:%s\n",user_data);
    printf("key:%s value:%s\n",key,value);
}

static void destroy_key(gpointer hash_data) {
    printf("destroy key:%s\n",hash_data);
    //因为我这里的键是数组形式不是指针所以不用释放内存。我就直接清空吧
/*    free(hash_data);
    hash_data = NULL;*/
    memset(hash_data,0,sizeof(hash_data));
}

static void destroy_value(gpointer hash_data) {
    printf("destroy value:%s\n",hash_data);
    //因为我这里的值是数组形式不是指针所以不用释放内存。我就直接清空吧
/*    free(hash_data);
    hash_data = NULL;*/
    memset(hash_data,0,sizeof(hash_data));
}

/*用来创建每个节点。每个键值对都需要有自己的内存*/
Node *create_node(char *key,char * value) {
    Node *node = NULL;
    node = malloc(sizeof(Node));
    if (node == NULL) {
        return NULL;
    }

    memset(node,0,sizeof(Node));
    strcpy(node->key,key);
    strcpy(node->value,value);

    return node;
}

int main()
{
    char buff[32] = {0};
    static GHashTable *g_hash = NULL;
    
    g_hash = g_hash_table_new_full(g_str_hash, g_int_equal, destroy_key, destroy_value);
    
    Node *node = create_node("name","xcy");
    if(node != NULL)
        g_hash_table_insert(g_hash, &node->key, &node->value);
    Node *node1 = create_node("age","18");
    if(node1 != NULL)
        g_hash_table_insert(g_hash, &node1->key, &node1->value);
    Node *node2 = create_node("sex","man");
    if(node2 != NULL)
        g_hash_table_insert(g_hash, &node2->key, &node2->value);
    Node *node3 = create_node("id","00001");
    if(node3 != NULL)
        g_hash_table_insert(g_hash, &node3->key, &node3->value);


    memcpy(buff,"this is parm",12);
    if(NULL != g_hash) {
        g_hash_table_foreach(g_hash, displayhash, buff);
    }
    

    printf("------------------free hashtable------------------------\n");

    g_hash_table_destroy(g_hash);
}

  

 

标签:glib,node,调用,hash,key,value,哈希,NULL,data
From: https://www.cnblogs.com/hshy/p/17292506.html

相关文章

  • glib GVariant
    GVariant*g_variant_new_boolean(gbooleanvalue){ gucharv=value; returng_variant_new_from_trusted(G_VARIANT_TYPE_BOOLEAN,&v,1);} typedefstruct_GVariantTypeGVariantType;/** *G_VARIANT_TYPE_BOOLEAN: * *Thetypeofavalueth......
  • 【转】【C#】 AForge调用摄像头
    AForge.NET专为计算机视觉和人工智能应用而设计,这种C#框架适用于图像处理、神经网络、遗传算法、模糊逻辑、机器学习和机器人等。该库是一个开源项目,包括:AForge.Imaging——一些日常的图像处理和过滤器 AForge.Vision——计算机视觉应用类库 AForge.Neuro——神经网络计算......
  • Parallel 会阻塞调用者吗
    提问Parallel会阻塞调用者吗回答会原因虽然parallel也是基于线程池,但是他也会阻塞调用者......
  • C#调用C++ 平台调用P/Invoke 字符串【三】
    Gitp-invoke源码地址 C#调用C++平台调用P/Invoke调用约定【一】C#调用C++平台调用P/Invoke函数指针/回调函数【二】C#调用C++平台调用P/Invoke字符串【三】C#调用C++平台调用P/Invoke错误码LastError【四】C#调用C++平台调用P/Invoke结构体--输入输出参数、返回值、返......
  • C#调用C++ 平台调用P/Invoke 函数指针/回调函数【二】
    Gitp-invoke源码地址 C#调用C++平台调用P/Invoke调用约定【一】C#调用C++平台调用P/Invoke函数指针/回调函数【二】C#调用C++平台调用P/Invoke字符串【三】C#调用C++平台调用P/Invoke错误码LastError【四】C#调用C++平台调用P/Invoke结构体--输入输出参数、返回值、返......
  • Ubuntu切换glibc版本
    Ubuntu切换glibc版本glibc是GNU发布的C语言标准库,不同版本的glibc中函数实现不同,可能导致程序运行结果不同。这里介绍如何切换不同版本的glibc来运行程序首先,要安装patchelf,这是给elf文件打补丁(修改elf文件属性,包括使用的glibc版本)的工具gitclonehttps://github.com/NixOS/pa......
  • C++库封装JNI接口——实现java调用c++
    1.JNI原理概述通常为了更加灵活高效地实现计算逻辑,我们一般使用C/C++实现,编译为动态库,并为其设置C接口和C++接口。用C++实现的一个库其实是一个或多个类的简单编译链接产物。然后暴露其实现类构造方法和纯虚接口类。这样就可以通过多态调用到库内部的实现类及其成员方法。进一步......
  • HJ19_简单错误记录_哈希
    思路:要实现字符串的分隔和按输入顺序输出,所以使用列表。两列表实现。知识点:1、python的可哈希不可哈希对象    详见:详解Python中的可哈希对象与不可哈希对象(二)-腾讯云开发者社区-腾讯云(tencent.com)   2、斜杆的“\”字符的读取与分隔“\\”用split()方法......
  • python 变量动态命名,赋值和调用
    变量动态命名foriinrange(3):exec("变量{}".format(i))变量动态赋值foriinrange(3):exec("变量{}={}*2".format(i,i))动态变量调用eval()执行完会返回结果,而exec()执行完不返回结果(http://c.biancheng.net/view/5683.html)a=1exec("a=2")#相当于直接执......
  • CF1200E Compress Words 字符串哈希/双重哈希
    题目地址题意:给你若干个字符串,答案串初始为空。第i步将第i个字符串加到答案串的后面,但是尽量地去掉重复部分(即去掉一个最长的、是原答案串的后缀、也是第i个串的前缀的字符串),求最后得到的字符串。Solution字符串哈希练习题,做完之后对哈希的理解更深刻了因为求原字符串的......