开启辅助访问 切换到宽版

精易论坛

 找回密码
 注册

QQ登录

只需一步,快速开始

用微信号发送消息登录论坛

新人指南 邀请好友注册 - 我关注人的新帖 教你赚取精币 - 每日签到


求职/招聘- 论坛接单- 开发者大厅

论坛版规 总版规 - 建议/投诉 - 应聘版主 - 精华帖总集 积分说明 - 禁言标准 - 有奖举报

查看: 965|回复: 8
收起左侧

[精币悬赏] 关于类_快速哈希表对象中的读问题

[复制链接]
结帖率:0% (0/2)
发表于 2022-5-8 22:49:11 | 显示全部楼层 |阅读模式   江苏省南京市
60精币
附 类_快速哈希表对象源码
源码中(HashTable_Get)是根据指定键读取取,寻求怎么添加一个根据指定值读取

要求和读写法类似




.版本 2

.子程序 HashTable_Get, 通用型, , 获取值
.参数 hHashTable, 整数型
.参数 key, 通用型, 参考
.局部变量 pKey, 整数型
.局部变量 ret, 整数型
.局部变量 hash, 整数型
.局部变量 index, 整数型
.局部变量 pe, 整数型
.局部变量 Entry_HashCode, 整数型
.局部变量 Entry_Key, 整数型
.局部变量 Entry_Value, 整数型
.局部变量 Entry_next, 整数型
.局部变量 HashTable_hHeap, 整数型, , , 堆句柄
.局部变量 HashTable_table, 整数型, , , 表
.局部变量 HashTable_tableLenth, 整数型, , , 表大小
.局部变量 HashTable_count, 整数型, , , 总数
.局部变量 HashTable_threshold, 整数型, , , 扩容临界值
.局部变量 HashTable_loadFactor, 小数型, , , 加载因子
.局部变量 HashTable_modCount, 整数型, , , 被修改次数
.局部变量 HashTable_keyType, 整数型
.局部变量 HashTable_valType, 整数型

pKey = 0
ret = 0
置入代码 ({ 139, 69, 12, 139, 0, 137, 69, 252 })
' mov eax,[ebp+12]
' mov eax,[eax]
' mov [ebp-04],eax
.如果真 (hHashTable = 0)
    .判断开始 (HashTable_valType = #整数型)
        置入代码 ({ 185, 1, 3, 0, 128 })
        ' mov ecx,0x80000301
    .判断 (HashTable_valType = #文本型)
        置入代码 ({ 185, 4, 0, 0, 128 })
        ' mov ecx,0x80000004
    .判断 (HashTable_valType = #字节集型)
        置入代码 ({ 185, 5, 0, 0, 128 })
        ' mov ecx,0x80000005
    .默认

    .判断结束
    置入代码 ({ 49, 192, 201, 194, 8, 0 })
    ' xor eax,eax
    ' leave
    ' retn 08
    返回 (0)
.如果真结束
HashTable_hHeap = 读内存_ (hHashTable, #ht_hHeap)
HashTable_table = 读内存_ (hHashTable, #ht_table)
HashTable_tableLenth = 读内存_ (hHashTable, #ht_tableLenth)
HashTable_count = 读内存_ (hHashTable, #ht_count)
HashTable_keyType = 读内存_ (hHashTable, #ht_keyType)
HashTable_valType = 读内存_ (hHashTable, #ht_valType)
hash = HashTable_GetHashCode (HashTable_keyType, key)
index = 位与 (hash, 2147483647) % HashTable_tableLenth
pe = 读内存 (HashTable_table + index × 4)
.判断循环首 (pe ≠ 0)
    Entry_HashCode = 读内存_ (pe, #e_hashCode)
    Entry_Key = 读内存_ (pe, #e_key)
    Entry_Value = 读内存_ (pe, #e_value)
    Entry_next = 读内存_ (pe, #e_next)
    .如果真 (Entry_HashCode = hash 且 HashTable_Equal (HashTable_keyType, Entry_Key, pKey))
        ret = HashTable_Assign (GetProcessHeap (), HashTable_valType, Entry_Value)
        .判断开始 (HashTable_valType = #整数型)
            置入代码 ({ 185, 1, 3, 0, 128 })
            ' mov ecx,0x80000301
        .判断 (HashTable_valType = #文本型)
            置入代码 ({ 185, 4, 0, 0, 128 })
            ' mov ecx,0x80000004
        .判断 (HashTable_valType = #字节集型)
            置入代码 ({ 185, 5, 0, 0, 128 })
            ' mov ecx,0x80000005
        .默认

        .判断结束
        置入代码 ({ 139, 69, 248, 201, 194, 8, 0 })
        ' mov eax,[ebp-08]
        ' leave
        ' ret 08
        返回 (0)
    .如果真结束
    pe = Entry_next
.判断循环尾 ()
.判断开始 (HashTable_valType = #整数型)
    置入代码 ({ 185, 1, 3, 0, 128 })
    ' mov ecx,0x80000301
.判断 (HashTable_valType = #文本型)
    置入代码 ({ 185, 4, 0, 0, 128 })
    ' mov ecx,0x80000004
.判断 (HashTable_valType = #字节集型)
    置入代码 ({ 185, 5, 0, 0, 128 })
    ' mov ecx,0x80000005
.默认

.判断结束
置入代码 ({ 49, 192, 201, 194, 8, 0 })
' xor eax,eax
' leave
' retn 08
返回 (0)







补充内容 (2022-5-9 15:20):
因为cha询的值可能存在多个,所以cha询到键可能也存在多个,所以返回的是数组数量,且参数key属于参考通用型数组

补充内容 (2022-5-9 15:51):
.版本 2

.子程序 HashTable_Get2, 整数型, , 返回数组数量
.参数 hHashTable, 整数型
.参数 key, 通用型, , 这是想cha询的值
.参数 keys, 通用型, 参考 数组, 这返数组

类_快速哈希表对象1.25.e

56.8 KB, 下载次数: 7, 下载积分: 精币 -1 枚

结帖率:95% (56/59)

签到天数: 20 天

发表于 2022-5-8 22:55:39 | 显示全部楼层   福建省福州市
那你就要把值写成键在写一个哈希表,这样就可以双向cha询了
回复

使用道具 举报

结帖率:100% (9/9)

签到天数: 16 天

发表于 2022-5-9 00:43:30 | 显示全部楼层   广西壮族自治区南宁市
枚举哈希表吧, 一般哈希表有提供枚举相关的命令吧, 值有可能会有重复的值, 但是键一般不会重复, 除非你用了可重复键名的哈希表
回复

使用道具 举报

发表于 2022-5-9 07:47:27 | 显示全部楼层   美国
下下来看看
回复

使用道具 举报

发表于 2022-5-9 07:47:58 | 显示全部楼层   美国
谢谢分享
回复

使用道具 举报

结帖率:0% (0/2)
 楼主| 发表于 2022-5-10 20:58:51 | 显示全部楼层   江苏省南京市
nikezhi 发表于 2022-5-8 22:55
那你就要把值写成键在写一个哈希表,这样就可以双向cha询了

不行呢,因为值会有很多一样的,
回复

使用道具 举报

结帖率:0% (0/2)
 楼主| 发表于 2022-5-10 21:00:19 | 显示全部楼层   江苏省南京市
nikezhi 发表于 2022-5-8 22:55
那你就要把值写成键在写一个哈希表,这样就可以双向cha询了

不行呢,因为值会有很多一样的,需要cha询的值,键放在数组中返回
回复

使用道具 举报

结帖率:0% (0/7)

签到天数: 1 天

发表于 2022-6-2 23:10:26 | 显示全部楼层   浙江省宁波市
来凑热闹
回复

使用道具 举报

结帖率:0% (0/2)
 楼主| 发表于 2022-11-4 17:25:17 | 显示全部楼层   江苏省南京市
取消悬赏
回复

使用道具 举报

您需要登录后才可以回帖 登录 | 注册

本版积分规则 致发广告者

发布主题 收藏帖子 返回列表

sitemap| 易语言源码| 易语言教程| 易语言论坛| 易语言模块| 手机版| 广告投放| 精易论坛
拒绝任何人以任何形式在本论坛发表与中华人民共和国法律相抵触的言论,本站内容均为会员发表,并不代表精易立场!
论坛帖子内容仅用于技术交流学习和研究的目的,严禁用于非法目的,否则造成一切后果自负!如帖子内容侵害到你的权益,请联系我们!
防范网络诈骗,远离网络犯罪 违法和不良信息举报电话0663-3422125,QQ: 793400750,邮箱:wp@125.la
Powered by Discuz! X3.4 揭阳市揭东区精易科技有限公司 ( 粤ICP备12094385号-1) 粤公网安备 44522102000125 增值电信业务经营许可证 粤B2-20192173

快速回复 返回顶部 返回列表