当前位置: 首页 > wzjs >正文

网站建设皖icp做个公司网站一般需要多少钱

网站建设皖icp,做个公司网站一般需要多少钱,wordpress模版头部文件,贵州软件开发 网站开发一. 简介 前面一篇文章简单学习了C语言中第三方库(uthash库)提供对哈希表的操作,文章如下: C语言中提供的第三方库uthash常用接口-CSDN博客 本文简单学习一下第三方库 uthash库对哈希表的操作。 二. uthash库哈希表操作示例 u…

 一. 简介

前面一篇文章简单学习了C语言中第三方库(uthash库)提供对哈希表的操作,文章如下:

C语言中提供的第三方库uthash常用接口-CSDN博客

本文简单学习一下第三方库 uthash库对哈希表的操作。

二. uthash库哈希表操作示例

uthash库提供了对不同类型数据类型的键值时的操作接口,这里举例key键值为 char* 类型,虽然是指针类型,但是进行比较时是对key键值的比较,而不是比较指针地址是否相等。所以,使用的是 uthash库中对字符串类型键的接口。

1. 定义哈希表结构体

首先需要定义哈希表结构体,该结构体包括要存储的数据和 UT_hash_handle句柄。例如如下:

#include <stdio.h>
#include <string.h>
#include <stdlib.h>
#include "uthash.h"//定义哈希表的结构体
typedef struct hash_node{char* key; //键char*  value; //值UT_hash_handle hh; //hthash库的哈希表句柄
} hash_node;hash_node* hash_table = NULL; //定义一个哈希表指针

可以看出,哈希表的结构体包括键值与实际数据。可以通过哈希函数将键值映射到哈希表中的某个位置。

2. 向哈希表插入新数据

将新的数据插入到哈希表中:

//将新数据插入到哈希表中
void insert_hash_table(const* char key, char* value) {if(!key) {return;}hash_node* out_node;//检查键是否已存在HASH_FIND_STR(hash_table, key, out_node);if(out_node) { //键已存在哈希表中,更新值(先释放旧值内存)free(out_node->value);out_node->value = strdup(value);if(!out_node->value) {fprintf(stderr, "内存分配失败!\n");}}//键不存在哈希表中hash_node* new_node = (hash_node*)malloc(sizeof(hash_node));new_node->key = strdup(key);new_node->value = strdup(value);if((!new_node->key) || (!new_node->value)) {free(new_node->key);free(new_node->value);free(new_node);return;}//将新键值对插入哈希表中HASH_ADD_KEYPTR(hash_handle, hash_table, new_node->key, strlen(new_node->key), new_node);
}

向哈希表中插入新元素时,首先检查新元素的键是否已存在哈希表中,已存在则更新key键对应的数据,否则,创建新的节点值并插入哈希表中。

2. 根据键查找对应的值

在哈希表中根据键查找对应的值,实现如下:

//根据键查找值
const char* find_by_key(const char* key) {hash_node* out_node = NULL;//根据键查找对应的值HASH_FIND_STR(hash_table, key, out_node);return out_node ? out_node->value : NULL;
}

3. 根据键值删除对应的数据

在哈希表查找某个键对应的数据,实现如下:

delete_data_by_key(const char* key) {hash_node * out_node = NULL;//根据键查找对应的值HASH_FIND_STR(hash_table, key, out_node);if(!out_node) {printf("not value by key!\n");return;}//删除key对应的值HASH_DEL(hash_table, out_node);free(out_node->key); //释放键内存free(out_node->value); //释放值内存free(out_node);  //释放节点内存
}

注意,当删除哈希表中键对应的值后,需要释放该键内存,值内存,以及该节点内存资源。

4. 遍历哈希表

遍历哈希表实现如下:

//遍历哈希表
void traverse_hash_table(hash_node* hash_table) {hash_node* hash_current, *hash_next;HASH_ITER(hash_handle, hash_table, hash_current, hash_next) {printf("current key: %s, current value: %s\n", hash_current->key, hash_current->value);}
}

5. 清空哈希表

清空哈希表使用  HASH_DEL(head, delptr) 宏定义,但是,内存释放还需要手动进行释放。

//清空哈希表
void clear_hash_table(void) {hash_node* hash_current, *hash_next;HASH_ITER(hash_handle, hash_table, hash_current, hash_next) {HASH_DEL(hash_table, hash_current);//需要手动释放内存free(hash_current->key);free(hash_current->value);free(hash_current);}

http://www.dtcms.com/wzjs/18645.html

相关文章:

  • 江苏 建设 招标有限公司网站广州市最新消息
  • 网络公司网站首页图片百度关键词排名怎么靠前
  • 楚雄网站制作色目人
  • 多语言的网站预防电信网络诈骗
  • 网站建设存在困难制作网站的工具
  • 广州手机网站建设费用商丘seo博客
  • 国内做五金加工的订单网站深圳网站快速排名优化
  • 教学类网站怎么做新出的app推广在哪找
  • wordpress搭建后域名打不开什么是seo标题优化
  • 国内旅行做行程网站大数据营销经典案例
  • 网站做缓存网络营销方式有哪些
  • 厦门短视频代运营公司常德seo快速排名
  • behance是什么网站营销型制作网站公司
  • 一站式做网站系统站外推广平台有哪些
  • 网站备案成功后怎么操作郑州网站优化外包
  • 东坑镇仿做网站全球疫情最新消息
  • 重庆网站页面优化北京网站优化指导
  • 建网站手机seo赚钱
  • 做经销找厂家好的网站亚马逊关键词工具哪个最准
  • 郑州专业制作网站费用网站竞价推广怎么做
  • 网站ui设计要点网站推广方案策划书2000
  • 如何攻击织梦做的网站方法网络推广优化工具
  • 硅云wordpress多站点微信软文怎么写
  • 软件开发找谁网站优化的方法
  • 专业网站建设哪里好哈尔滨seo网络推广
  • wordpress植物网站百度云盘资源
  • 专门做衣服的网站百度指数功能
  • 网页广告图seo搜索优化公司报价
  • 在自己的网站做百度搜索框百度推广营销
  • 做卡通的素材网站优化设计答案六年级上册语文