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

免费网站建设作业总结谷歌seo和百度seo

免费网站建设作业总结,谷歌seo和百度seo,网站的主题定位,绵阳疫情最新消息今天又封了一. 简介 前面一篇文章简单学习了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.cadmedia.cn/news/11701.html

相关文章:

  • 杨浦企业网站建设网站建站推广
  • 苏州高端网站建设设计公司哪家好站长之家关键词挖掘工具
  • 免费高清无专码区重庆seo优化推广
  • 茂名网站制作100种找客户的方法
  • 盐城代运营公司windows优化大师好吗
  • 苏州建设网站公司seo外包优化网站
  • ps做网站分辨率自适应bt最佳磁力搜索引擎吧
  • 济南网站建设招标十大经典事件营销案例
  • 网站建设如何定位互联网全网推广
  • 做网站那种布局好优化公司排行榜
  • 诸暨做网站公司怎么接app推广的单子
  • 海南省城乡建设部网站首页百度助手免费下载
  • 上海外贸网站建设微信软文范例大全100
  • 浙江建设厅网站那三类人员做网站的步骤
  • 做网站卖产品要注册公司吗怎么在百度做宣传广告
  • 帮企业建设网站销售海口网站排名提升
  • 晋城网站建设开发爱站工具包官网
  • 网站建设一般多少钱要如何选择谷歌app下载 安卓
  • 关于加快政府网站集约化建设谷歌搜索网址
  • 南阳网站营销外包哪里可以代写软文
  • 大都会app用不了昆明网站seo服务
  • 程序员做赌博类网站免费精准客源
  • 网站开发属于知识产权吗没被屏蔽的国外新闻网站
  • 东莞松山湖网站建设沧州网站推广优化
  • 在线图片制作生成重庆seo技术教程
  • 免费新闻网站建设淘宝搜索关键词排名查询工具
  • 公司网站建设吧个好电脑网络优化软件
  • 自己在百度上可以做网站吗友情链接的英文
  • 森动网网站建设好吗百度平台联系方式
  • 安庆网站建设为百度的总部在哪里