Ai
1 Star 4 Fork 4

觉皇/HashMap

加入 Gitee
与超过 1200万 开发者一起发现、参与优秀开源项目,私有仓库也完全免费 :)
免费加入
文件
该仓库未声明开源许可证文件(LICENSE),使用请关注具体项目描述及其代码上游依赖。
克隆/下载
main.c 1.61 KB
一键复制 编辑 原始数据 按行查看 历史
觉皇 提交于 2019-12-05 16:38 +08:00 . first
#include <stdio.h>
#include "HashMap.h"
#define Put(key, value) HashMap_Put(hashMap, key, value)
#define Get(key) HashMap_Get(hashMap, key)
#define GetKesy(keys, count) HashMap_GetKeys(hashMap, keys, count)
#define Remove(key) HashMap_Remove(hashMap, key)
#define Clear() HashMap_Clear(hashMap)
#define Exists(key) HashMap_Exists(hashMap, key)
int main()
{
char pairs[][2][10] =
{
{"key1", "value1"},
{"key2", "value2"},
{"key3", "value3"}
};
const unsigned int npair = sizeof(pairs) / sizeof(pairs[0]);
// 初始化自建内存池
mem_init();
// 创建HashMap
HashMap *hashMap = HashMap_Create(10);
// 加入和获取
for (int i = 0; i != npair; i++)
{
Put(pairs[i][0], pairs[i][1]);
printf("[%s] ", Get(pairs[i][0]));
}
printf("\r\n");
// 查看内存池信息
printf("memory: <preused:%.2f%%> <used:%d> <free:%d> \r\n", mem_perused(), mem_getused(), mem_getfree());
// 获取所有key
int count = 0;
uint8_t *keys[10];
GetKesy(keys, &count);
for (int j = 0; j < count; ++j)
{
printf("[%s] ", keys[j]);
}
printf("\r\n");
// 删除
Remove("key1");
// 检测是否存在
bool isExists = Exists("key1");
printf("%s\r\n", isExists ? "true" : "false");
// 清空
Clear();
// 销毁HashMap
HashMap_Destroy(hashMap);
// 查看内存池信息
printf("memory: <preused:%.2f%%> <used:%d> <free:%d> \r\n", mem_perused(), mem_getused(), mem_getfree());
return 0;
}
Loading...
马建仓 AI 助手
尝试更多
代码解读
代码找茬
代码优化
C
1
https://gitee.com/jhembed/HashMap.git
git@gitee.com:jhembed/HashMap.git
jhembed
HashMap
HashMap
master

搜索帮助