1 Star 2 Fork 0

我的天啊123/New-C

加入 Gitee
与超过 1200万 开发者一起发现、参与优秀开源项目,私有仓库也完全免费 :)
免费加入
文件
该仓库未声明开源许可证文件(LICENSE),使用请关注具体项目描述及其代码上游依赖。
克隆/下载
map.c 2.79 KB
一键复制 编辑 原始数据 按行查看 历史
我的天啊123 提交于 2021-08-25 23:51 . init
#include <stdio.h>
#include <stdlib.h>
#include <string.h>
#include "map.h"
#define HASH_COUNT 16 /* hash table 默认长度 */
/* 解析字符串的 hash index */
int ParseIndex(char * name, int hash_count){
int h=0;
for (h=0; *name!=0; name++)
{
h <<= 8;
h += (unsigned char) *name;
//需要对2的次幂进行求余时,可以是使用&运算符来代替%
// 0-15一共16个数是 2的4次方
// 余数肯定不会超过 2的4次方, 所以只需要对低4位按位与;
h &= hash_count-1;
}
return h;
}
//初始化Map
Map *CreateMap(){
Map * hash = (Map *)malloc(sizeof(Map));
hash->node_count = 0;
hash->hash_count = HASH_COUNT;
hash->list = (Node **)calloc(HASH_COUNT, sizeof(Node*));
return hash;
}
// 查找node
Node * FindKey(Node *n, char * key){
Node *p;
for(p=n; p; p=p->next) if( EQUAL(p->key, key) ) break;
return p;
}
//查找node-list
Node * FindNode(Node ** list, char *key){
Node *n =list(list, FindIndex(key, HASH_COUNT) );
Node *p= FindKey(n, key );
return p;
}
//赋值
int SetValue(Map *format, variable * new, char * key){
int inx = FindIndex(key, HASH_COUNT);
Node *n =list(format->list, inx);
Node *p;
for(p=n; p; p=p->next){
if( EQUAL(p->key, key) ){
p->data = new;
return 1;
}
}
Node * node = (Node *)malloc(sizeof(Node));
node->key = key;
node->data = new;
if(n){
// 如果链表存在,查找最后一个
for(p=n; p; p=p->next) if(!p->next) break;
p->next = node;
}else{
// 链表不存在, 当前节点为第1个
list(format->list, inx) = node;
}
format->node_count++;
return 0;
}
//取值
variable *GetValue(Map *format, char *key){
Node *n = FindNode(format->list, key);
if(n) {
return n->data;
}
else{
return NULL;
}
}
void MapFree(Map *format){
for(int i=0; i<HASH_COUNT; i++){
Node *n =list(format->list, i);
NodeFree(n);
}
free(format->list);
free(format);
}
void NodeFree(Node *list){
Node *p;
for(p=list; p; p=p->next) free(p);
}
VarList * GetVarListMemory(){
VarList * list = (VarList*)malloc(sizeof(VarList));
list->var = CreateMap();
return list;
}
/**
* 查找变量
*/
variable * GetMapValue(VarList *var_list, char * key, int is_exit){
if(!is_exit) return GetValue(var_list->var, key);
VarList *p;
for( p = var_list; p; p=p->next){
variable * val = GetValue(p->var, key);
if(val) return val;
}
printf("Can't find variable: %s\n", key);
exit(0);
}
Loading...
马建仓 AI 助手
尝试更多
代码解读
代码找茬
代码优化
1
https://gitee.com/zxc321/new-c.git
[email protected]:zxc321/new-c.git
zxc321
new-c
New-C
master

搜索帮助