命令调用先构建hashTable

GPT 代码改

#include <stdio.h>
#include <stdlib.h>
#include <string.h>#define TABLE_SIZE 256struct Node {char *key;void *value;struct Node *next;
};struct HashTable {struct Node *table[TABLE_SIZE];
};void initHashTable(struct HashTable *hashTable) {for (int i = 0; i < TABLE_SIZE; i++) {hashTable->table[i] = NULL;}
}int hashFunction(char *key) {unsigned long hash = 0;int c;while ((c = *key++)) {hash = c + (hash << 6) + (hash << 16) - hash;}return hash % TABLE_SIZE;
}void insert(struct HashTable *hashTable, char *key, void *value) {int index = hashFunction(key);struct Node *newNode = (struct Node *)malloc(sizeof(struct Node));if (newNode == NULL) {fprintf(stderr, "Memory allocation failed\n");exit(EXIT_FAILURE);}newNode->key = strdup(key);newNode->value = value;newNode->next = NULL;newNode->next = hashTable->table[index];hashTable->table[index] = newNode;
}void *get(struct HashTable *hashTable, char *key) {int index = hashFunction(key);struct Node *current = hashTable->table[index];while (current != NULL) {if (strcmp(current->key, key) == 0) {return current->value;}current = current->next;}return 0;
}void removeKey(struct HashTable *hashTable, char *key) {int index = hashFunction(key);struct Node *current = hashTable->table[index];struct Node *prev = NULL;while (current != NULL) {if (strcmp(current->key, key) == 0) {if (prev == NULL) {hashTable->table[index] = current->next;} else {prev->next = current->next;}free(current->key);free(current);return;}prev = current;current = current->next;}
}void freeHashTable(struct HashTable *hashTable) {for (int i = 0; i < TABLE_SIZE; i++) {struct Node *current = hashTable->table[i];while (current != NULL) {struct Node *next = current->next;free(current->key);free(current);current = next;}}
}void hello() { printf("hello\n"); }
void world() { printf("world\n"); }int main() {struct HashTable hashTable;initHashTable(&hashTable);insert(&hashTable, "hello", hello);insert(&hashTable, "world", world);((void (*)())get(&hashTable, "hello"))();freeHashTable(&hashTable);return 0;}

对驱动来说,别名映射很重要,就像生活不能没有太阳

在这里插入图片描述

修改后

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.hqwc.cn/news/278629.html

如若内容造成侵权/违法违规/事实不符,请联系编程知识网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

用CC三维建模建出的OSGB格式,用模方打不开,显示该路径包含OSGB瓦块数量0,是什么原因?

答&#xff1a;模方只识别tile命名的模型文件&#xff0c;此模型是不分块输出&#xff0c;要平面切块重新跑。 模方是一款针对实景三维模型的冗余碎片、水面残缺、道路不平、标牌破损、纹理拉伸模糊等共性问题研发的实景三维模型修复编辑软件。模方4.1新增自动单体化建模功能&…

字符设备驱动模块的编译

一. 简介 本文继上一篇文章的学习&#xff0c;上一篇文章学习了字符设备驱动框架的初步编写。文章地址如下&#xff1a; 字符设备驱动框架的编写-CSDN博客 本文对上一篇编写的驱动模块初步框架进行编译。 二. 字符设备驱动模块的编译 上一篇文章&#xff0c;编写了字符设备…

Kubernetes 的用法和解析 -- 2

一.集群常用指令 1.1 基础控制指令 # 查看对应资源: 状态 $ kubectl get <SOURCE_NAME> -n <NAMESPACE> -o wide [rootkube-master ~]# kubectl get pods -n kuboard -o wide# 查看对应资源: 事件信息 $ kubectl describe <SOURCE_NAME> <SOURCE_NAME_R…

Linux:符号和符号表

文章目录 什么是符号&#xff1f;什么是符号表&#xff1f;全局符号和本地符号1. 全局符号&#xff1a;symtab符号表 2. 本地符号&#xff1a; 符号在汇编阶段符号在链接阶段1.由模块 m 定义并能被其他模块引用的全局符号。2.由其他模块定义并被模块 m 引用的全局符号。3.只被模…

如何实现一个 RPC 框架?

如果让你自己设计 RPC 框架你会如何设计&#xff1f; 一般情况下&#xff0c; RPC 框架不仅要提供服务发现功能&#xff0c;还要提供负载均衡、容错等功能&#xff0c;这样的 RPC 框架才算真正合格的。 为了便于小伙伴们理解&#xff0c;我们先从一个最简单的 RPC 框架使用示意…

深入理解网络 I/O:单 Selector 多线程|单线程模型

&#x1f52d; 嗨&#xff0c;您好 &#x1f44b; 我是 vnjohn&#xff0c;在互联网企业担任 Java 开发&#xff0c;CSDN 优质创作者 &#x1f4d6; 推荐专栏&#xff1a;Spring、MySQL、Nacos、Java&#xff0c;后续其他专栏会持续优化更新迭代 &#x1f332;文章所在专栏&…

【Android】在Android上使用mlKit构建人脸检测程序

在Android上构建人脸检测程序 目录 1、导入mlKit依赖包2、配置人脸检测器并且获取人脸检测器3、加载图片资源4、调用人脸检测器5、绘制矩形边框6、完整代码7、效果展示 1、导入mlKit依赖包 dependencies {// ...// Use this dependency to bundle the model with your appi…

肚子排气方法

1&#xff0c;保持30s的抱膝。 2&#xff0c;身体侧卧&#xff0c;打开髋和骨盆。停留20-30s。 3&#xff0c;脚后跟抬起&#xff0c;重心放在脚前掌&#xff0c;腹部贴大腿&#xff0c;双手左侧右侧来回转&#xff0c;10次。 4&#xff0c;吹风机&#xff0c;热风从脚开始打热…

uniGUI for Delphi UniSweetAlert控件详解

UniSweetAlert是UniGUI后期版本新增的一个界面友好的消息提示和输入控件&#xff0c;是ShowMessageN的升级版&#xff0c;UniSweetAlert增加了更多的可控制属性。 属性介绍 1、AlertType&#xff1a;提示类型&#xff0c;分为atError、atSuccess、atInfo、atQuestion、atWarni…

产品入门第五讲:Axure交互和情境

目录 一.Axure交互和情境的介绍 1.交互介绍 概念 常见的Axure交互设计技巧 2.情境介绍 概念 常见的Axure情境设计技巧&#xff1a; 二.实例展示 1.ERP登录页到主页的跳转 2.ERP的菜单跳转到各个页面 &#x1f4da;&#x1f4da; &#x1f3c5;我是默&#xff0c;一个…

Github 2023-12-16开源项目日报Top10

根据Github Trendings的统计&#xff0c;今日(2023-12-16统计)共有10个项目上榜。根据开发语言中项目的数量&#xff0c;汇总情况如下&#xff1a; 开发语言项目数量Python项目2非开发语言项目2TypeScript项目1Jupyter Notebook项目1Go项目1PHP项目1JavaScript项目1C#项目1 精…

实战 | OpenCV传统方法实现密集圆形分割与计数(详细步骤 + y源码)

导 读 本文主要介绍基于OpenCV传统方法实现密集圆形分割与计数应用,并给详细步骤和代码。 背景介绍 实例图片来源于网络,目标是分割下图中圆形目标并计数。 本文实现效果如下: 实现步骤 【1】灰度转换 + 均值滤波 + 二值化,得到参考背景 img = cv2.imread(src.jpg)c…