精易论坛

标题: 终极版哈希表 全面优化代码 提升速度 [打印本页]

作者: 5182235367    时间: 2017-4-30 00:45
标题: 终极版哈希表 全面优化代码 提升速度
终极版哈希表 全面优化代码 提升速度
废话不多说 自己下载测试


补充内容 (2018-12-9 14:18):
最新版本:https://125.confly.eu.org/forum.php?mod=viewthread&tid=14261124&extra=

QQ图片20170429233706.png (53.79 KB, 下载次数: 91)

QQ图片20170429233706.png

终极版哈希-6.rar

12.73 KB, 下载次数: 1265, 下载积分: 精币 -2 枚


作者: 进击    时间: 2017-4-30 00:52
能给出一些好在应用不?
作者: 凌哥    时间: 2017-4-30 00:58

作者: 末页    时间: 2017-4-30 01:03
HashMap?
前两天好像见过
作者: huyuan    时间: 2017-4-30 10:48
要是能把嘻哈表改成高级表格或者超级列表框就好了
作者: 勾栏听曲    时间: 2017-4-30 11:47
支持开源,。。
作者: 网上邻居007    时间: 2017-4-30 12:27
支持看开源
作者: jy896009    时间: 2017-4-30 21:02
支持看开源
作者: kisyan    时间: 2017-5-1 23:16
有啥用啊?
作者: 调皮的男孩    时间: 2017-5-2 10:50
学习 学习
作者: sqyclycd123    时间: 2017-5-4 15:43
谢谢分享,但是我技术还不够。先看看
作者: 天线宝宝520    时间: 2017-5-23 10:55
这个怎么用啊,一直不懂啊
作者: hi虫    时间: 2017-6-4 11:56
本帖最后由 hi虫 于 2017-6-4 11:58 编辑

不支持程序集级别的类_哈希表变量吗?会报数组下标溢出异常全局变量也是

作者: 5182235367    时间: 2017-6-4 12:16
hi虫 发表于 2017-6-4 11:56
不支持程序集级别的类_哈希表变量吗?会报数组下标溢出异常全局变量也是

我还真没发现有这样的情况
把你代码给我看看
作者: 痞子张    时间: 2017-6-13 14:49
速度上应该无可挑剔 但是功能比较弱 因为看不懂改装不了 我觉得 可以出一个慢速版 把功能提上去 两个版本都有的选择
作者: lancechung    时间: 2017-6-21 18:48
111111111111
作者: fenchen    时间: 2017-6-30 00:02
能不能用????????????
作者: 5182235367    时间: 2017-6-30 14:22
fenchen 发表于 2017-6-30 00:02
能不能用????????????

我写的功能,都是我做软件需要用到才会去弄,我一直在用,不过不是现在的版本,我用的优化了一些代码
不过现在的版本也可以用,需要自己修复一个问题,重定义数组维数
作者: 5182235367    时间: 2017-6-30 14:23
fenchen 发表于 2017-6-30 00:02
能不能用????????????

我写的功能,都是我做软件需要用到才会去弄,我一直在用,不过不是现在的版本,我用的优化了一些代码
不过现在的版本也可以用,需要自己修复一个问题,重定义数组维数
作者: 5182235367    时间: 2017-6-30 14:23
fenchen 发表于 2017-6-30 00:02
能不能用????????????

我写的功能,都是我做软件需要用到才会去弄,我一直在用,不过不是现在的版本,我用的优化了一些代码
不过现在的版本也可以用,需要自己修复一个问题,重定义数组维数
作者: sbnb2015    时间: 2017-7-1 15:32
这绝对是好东西,应该就是python中的字典了吧。虽然我还不知道楼主的怎么使用,但真的一直在为易语言编程找这种东西,今天真的是踏破铁鞋无觅处,得来全不费功夫。谢谢楼主分享,最好能给个例子做应用教程更好。

需要重定义数组维数?什么意思??
作者: wuhaiyi    时间: 2017-8-2 23:51
字典用惯了。。。
作者: 百DU第一答题王    时间: 2017-8-7 23:47
提示: 作者被禁止或删除 内容自动屏蔽
作者: si515    时间: 2017-8-8 21:09
百DU第一答题王 发表于 2017-8-7 23:47
你把哈希类写在程序集变量或者写在全局变量里面  直接就会报错数组越界
  
子程序名返回值类型公开备 注
哈希_初始化  
重定义数组 (程_哈希类型, 假, 11)
如果真 (程_哈希类型 [1].类型 = 0)
程_哈希类型 [1].类型 = #内部_哈希类型_字节型
程_哈希类型 [1].取值 = 到整数 (&哈希_取值_1)
程_哈希类型 [1].返回 = 到整数 (&哈希_返回_4)
程_哈希类型 [2].类型 = #内部_哈希类型_短整数型
程_哈希类型 [2].取值 = 到整数 (&哈希_取值_2)
程_哈希类型 [2].返回 = 到整数 (&哈希_返回_4)
程_哈希类型 [3].类型 = #内部_哈希类型_整数型
程_哈希类型 [3].取值 = 到整数 (&哈希_取值_4)
程_哈希类型 [3].返回 = 到整数 (&哈希_返回_4)
程_哈希类型 [4].类型 = #内部_哈希类型_长整数型
程_哈希类型 [4].取值 = 到整数 (&哈希_取值_8)
程_哈希类型 [4].返回 = 到整数 (&哈希_返回_8)
程_哈希类型 [5].类型 = #内部_哈希类型_小数型
程_哈希类型 [5].取值 = 到整数 (&哈希_取值_4)
程_哈希类型 [5].返回 = 到整数 (&哈希_返回_4)
程_哈希类型 [6].类型 = #内部_哈希类型_双精度小数型
程_哈希类型 [6].取值 = 到整数 (&哈希_取值_8)
程_哈希类型 [6].返回 = 到整数 (&哈希_返回_8)
程_哈希类型 [7].类型 = #内部_哈希类型_逻辑型
程_哈希类型 [7].取值 = 到整数 (&哈希_取值_4)
程_哈希类型 [7].返回 = 到整数 (&哈希_返回_4)
程_哈希类型 [8].类型 = #内部_哈希类型_日期时间型
程_哈希类型 [8].取值 = 到整数 (&哈希_取值_8)
程_哈希类型 [8].返回 = 到整数 (&哈希_返回_8)
程_哈希类型 [9].类型 = #内部_哈希类型_子程序指针
程_哈希类型 [9].取值 = 到整数 (&哈希_取值_4)
程_哈希类型 [9].返回 = 到整数 (&哈希_返回_4)
程_哈希类型 [10].类型 = #内部_哈希类型_文本型
程_哈希类型 [10].取值 = 到整数 (&哈希_取值_文本型)
程_哈希类型 [10].返回 = 到整数 (&哈希_返回_文本型)
程_哈希类型 [11].类型 = #内部_哈希类型_字节集
程_哈希类型 [11].取值 = 到整数 (&哈希_取值_字节集)
程_哈希类型 [11].返回 = 到整数 (&哈希_返回_字节集)
程_码表 = { 0, 1996959894, -301047508, -1727442502, 124634137, 1886057615, -379345611, -1637575261, 249268274, 2044508324, -522852066, -1747789432, 162941995, 2125561021, -407360249, -1866523247, 498536548, 1789927666, -205950648, -2067906082, 450548861, 1843258603, -187386543, -2083289657, 325883990, 1684777152, -43845254, -1973040660, 335633487, 1661365465, -99664541, -1928851979, 997073096, 1281953886, -715111964, -1570279054, 1006888145, 1258607687, -770865667, -1526024853, 901097722, 1119000684, -608450090, -1396901568, 853044451, 1172266101, -589951537, -1412350631, 651767980, 1373503546, -925412992, -1076862698, 565507253, 1454621731, -809855591, -1195530993, 671266974, 1594198024, -972236366, -1324619484, 795835527, 1483230225, -1050600021, -1234817731, 1994146192, 31158534, -1731059524, -271249366, 1907459465, 112637215, -1614814043, -390540237, 2013776290, 251722036, -1777751922, -519137256, 2137656763, 141376813, -1855689577, -429695999, 1802195444, 476864866, -2056965928, -228458418, 1812370925, 453092731, -2113342271, -183516073, 1706088902, 314042704, -1950435094, -54949764, 1658658271, 366619977, -1932296973, -69972891, 1303535960, 984961486, -1547960204, -725929758, 1256170817, 1037604311, -1529756563, -740887301, 1131014506, 879679996, -1385723834, -631195440, 1141124467, 855842277, -1442165665, -586318647, 1342533948, 654459306, -1106571248, -921952122, 1466479909, 544179635, -1184443383, -832445281, 1591671054, 702138776, -1328506846, -942167884, 1504918807, 783551873, -1212326853, -1061524307, -306674912, -1698712650, 62317068, 1957810842, -355121351, -1647151185, 81470997, 1943803523, -480048366, -1805370492, 225274430, 2053790376, -468791541, -1828061283, 167816743, 2097651377, -267414716, -2029476910, 503444072, 1762050814, -144550051, -2140837941, 426522225, 1852507879, -19653770, -1982649376, 282753626, 1742555852, -105259153, -1900089351, 397917763, 1622183637, -690576408, -1580100738, 953729732, 1340076626, -776247311, -1497606297, 1068828381, 1219638859, -670225446, -1358292148, 906185462, 1090812512, -547295293, -1469587627, 829329135, 1181335161, -882789492, -1134132454, 628085408, 1382605366, -871598187, -1156888829, 570562233, 1426400815, -977650754, -1296233688, 733239954, 1555261956, -1026031705, -1244606671, 752459403, 1541320221, -1687895376, -328994266, 1969922972, 40735498, -1677130071, -351390145, 1913087877, 83908371, -1782625662, -491226604, 2075208622, 213261112, -1831694693, -438977011, 2094854071, 198958881, -2032938284, -237706686, 1759359992, 534414190, -2118248755, -155638181, 1873836001, 414664567, -2012718362, -15766928, 1711684554, 285281116, -1889165569, -127750551, 1634467795, 376229701, -1609899400, -686959890, 1308918612, 956543938, -1486412191, -799009033, 1231636301, 1047427035, -1362007478, -640263460, 1088359270, 936918000, -1447252397, -558129467, 1202900863, 817233897, -1111625188, -893730166, 1404277552, 615818150, -1160759803, -841546093, 1423857449, 601450431, -1285129682, -1000256840, 1567103746, 711928724, -1274298825, -1022587231, 1510334235, 755167117 }
程_码表指针 = 取数组指针_整数 (程_码表)
我刚刚测试了一下作者的程序,推测应该是易语言的问题,你在这里改成这样
作者: si515    时间: 2017-8-8 21:09
本帖最后由 si515 于 2017-8-8 21:12 编辑
百DU第一答题王 发表于 2017-8-7 23:47
你把哈希类写在程序集变量或者写在全局变量里面  直接就会报错数组越界
  
子程序名返回值类型公开备 注
哈希_初始化  
重定义数组 (程_哈希类型, 假, 11)
如果真 (程_哈希类型 [1].类型 = 0)
程_哈希类型 [1].类型 = #内部_哈希类型_字节型
程_哈希类型 [1].取值 = 到整数 (&哈希_取值_1)
程_哈希类型 [1].返回 = 到整数 (&哈希_返回_4)
程_哈希类型 [2].类型 = #内部_哈希类型_短整数型
程_哈希类型 [2].取值 = 到整数 (&哈希_取值_2)
程_哈希类型 [2].返回 = 到整数 (&哈希_返回_4)
程_哈希类型 [3].类型 = #内部_哈希类型_整数型
程_哈希类型 [3].取值 = 到整数 (&哈希_取值_4)
程_哈希类型 [3].返回 = 到整数 (&哈希_返回_4)
程_哈希类型 [4].类型 = #内部_哈希类型_长整数型
程_哈希类型 [4].取值 = 到整数 (&哈希_取值_8)
程_哈希类型 [4].返回 = 到整数 (&哈希_返回_8)
程_哈希类型 [5].类型 = #内部_哈希类型_小数型
程_哈希类型 [5].取值 = 到整数 (&哈希_取值_4)
程_哈希类型 [5].返回 = 到整数 (&哈希_返回_4)
程_哈希类型 [6].类型 = #内部_哈希类型_双精度小数型
程_哈希类型 [6].取值 = 到整数 (&哈希_取值_8)
程_哈希类型 [6].返回 = 到整数 (&哈希_返回_8)
程_哈希类型 [7].类型 = #内部_哈希类型_逻辑型
程_哈希类型 [7].取值 = 到整数 (&哈希_取值_4)
程_哈希类型 [7].返回 = 到整数 (&哈希_返回_4)
程_哈希类型 [8].类型 = #内部_哈希类型_日期时间型
程_哈希类型 [8].取值 = 到整数 (&哈希_取值_8)
程_哈希类型 [8].返回 = 到整数 (&哈希_返回_8)
程_哈希类型 [9].类型 = #内部_哈希类型_子程序指针
程_哈希类型 [9].取值 = 到整数 (&哈希_取值_4)
程_哈希类型 [9].返回 = 到整数 (&哈希_返回_4)
程_哈希类型 [10].类型 = #内部_哈希类型_文本型
程_哈希类型 [10].取值 = 到整数 (&哈希_取值_文本型)
程_哈希类型 [10].返回 = 到整数 (&哈希_返回_文本型)
程_哈希类型 [11].类型 = #内部_哈希类型_字节集
程_哈希类型 [11].取值 = 到整数 (&哈希_取值_字节集)
程_哈希类型 [11].返回 = 到整数 (&哈希_返回_字节集)
程_码表 = { 0, 1996959894, -301047508, -1727442502, 124634137, 1886057615, -379345611, -1637575261, 249268274, 2044508324, -522852066, -1747789432, 162941995, 2125561021, -407360249, -1866523247, 498536548, 1789927666, -205950648, -2067906082, 450548861, 1843258603, -187386543, -2083289657, 325883990, 1684777152, -43845254, -1973040660, 335633487, 1661365465, -99664541, -1928851979, 997073096, 1281953886, -715111964, -1570279054, 1006888145, 1258607687, -770865667, -1526024853, 901097722, 1119000684, -608450090, -1396901568, 853044451, 1172266101, -589951537, -1412350631, 651767980, 1373503546, -925412992, -1076862698, 565507253, 1454621731, -809855591, -1195530993, 671266974, 1594198024, -972236366, -1324619484, 795835527, 1483230225, -1050600021, -1234817731, 1994146192, 31158534, -1731059524, -271249366, 1907459465, 112637215, -1614814043, -390540237, 2013776290, 251722036, -1777751922, -519137256, 2137656763, 141376813, -1855689577, -429695999, 1802195444, 476864866, -2056965928, -228458418, 1812370925, 453092731, -2113342271, -183516073, 1706088902, 314042704, -1950435094, -54949764, 1658658271, 366619977, -1932296973, -69972891, 1303535960, 984961486, -1547960204, -725929758, 1256170817, 1037604311, -1529756563, -740887301, 1131014506, 879679996, -1385723834, -631195440, 1141124467, 855842277, -1442165665, -586318647, 1342533948, 654459306, -1106571248, -921952122, 1466479909, 544179635, -1184443383, -832445281, 1591671054, 702138776, -1328506846, -942167884, 1504918807, 783551873, -1212326853, -1061524307, -306674912, -1698712650, 62317068, 1957810842, -355121351, -1647151185, 81470997, 1943803523, -480048366, -1805370492, 225274430, 2053790376, -468791541, -1828061283, 167816743, 2097651377, -267414716, -2029476910, 503444072, 1762050814, -144550051, -2140837941, 426522225, 1852507879, -19653770, -1982649376, 282753626, 1742555852, -105259153, -1900089351, 397917763, 1622183637, -690576408, -1580100738, 953729732, 1340076626, -776247311, -1497606297, 1068828381, 1219638859, -670225446, -1358292148, 906185462, 1090812512, -547295293, -1469587627, 829329135, 1181335161, -882789492, -1134132454, 628085408, 1382605366, -871598187, -1156888829, 570562233, 1426400815, -977650754, -1296233688, 733239954, 1555261956, -1026031705, -1244606671, 752459403, 1541320221, -1687895376, -328994266, 1969922972, 40735498, -1677130071, -351390145, 1913087877, 83908371, -1782625662, -491226604, 2075208622, 213261112, -1831694693, -438977011, 2094854071, 198958881, -2032938284, -237706686, 1759359992, 534414190, -2118248755, -155638181, 1873836001, 414664567, -2012718362, -15766928, 1711684554, 285281116, -1889165569, -127750551, 1634467795, 376229701, -1609899400, -686959890, 1308918612, 956543938, -1486412191, -799009033, 1231636301, 1047427035, -1362007478, -640263460, 1088359270, 936918000, -1447252397, -558129467, 1202900863, 817233897, -1111625188, -893730166, 1404277552, 615818150, -1160759803, -841546093, 1423857449, 601450431, -1285129682, -1000256840, 1567103746, 711928724, -1274298825, -1022587231, 1510334235, 755167117 }
程_码表指针 = 取数组指针_整数 (程_码表)
我刚刚测试了一下作者的程序,推测应该是有问题,但是不知道是不是易语言的问题,你在这里改成这样
作者: si515    时间: 2017-8-8 21:11
百DU第一答题王 发表于 2017-8-7 23:47
你把哈希类写在程序集变量或者写在全局变量里面  直接就会报错数组越界

我看了一下作者的代码,目测应该是有问题,但是是不是易语言的不确定
改法如下
作者: SoloCat    时间: 2017-9-26 09:44
不支持多线程。没有做保护。。。没啥用处
作者: jingyi    时间: 2017-10-7 19:23
很好,多谢,还是字典好用
作者: pppp8888    时间: 2017-10-27 02:02
  哈希 、 字典  是啥东西,咋用
作者: tianyuan0322    时间: 2017-11-7 21:41
这个是好东西
作者: 星云散落    时间: 2017-11-13 20:12
感谢分享 发布辛苦
作者: RDTB    时间: 2017-12-17 17:29
像java哈希可以直接存入类,易语言好像不行
作者: hhhql    时间: 2017-12-20 16:55
感谢分享 发布辛苦
作者: hwt875098552    时间: 2018-1-6 15:22
学习学习!!!!!!
作者: 章武    时间: 2018-2-2 22:14
感谢分享 发布辛苦
作者: Kano2003    时间: 2018-2-18 13:13
emmm不支持多线程,没有做保护
作者: 牧师    时间: 2018-3-2 16:34
下个来看看。。。。。。
作者: ashwolf    时间: 2018-3-28 13:02
终极版哈希表 全面优化代码 提升速度

作者: anim510    时间: 2018-4-28 18:32

作者: pei5    时间: 2018-6-10 09:37
搞下来试试,正需要
作者: ruidesi    时间: 2018-6-11 16:50
拿来测试,谢谢了
作者: 6897871    时间: 2018-7-16 18:47

作者: a305783289    时间: 2018-9-10 14:20
感谢分享学习学习~
作者: fasd346asf    时间: 2018-9-15 14:24
太感谢了,最近正好需要这个功能,大神啊,太太太太太太感谢您那
作者: 走一回    时间: 2018-10-2 09:54
具体怎么用,能出个例子吗?
作者: youyaang    时间: 2018-10-14 14:53
谢谢分享,试试这个hash函数怎么样
作者: linuxlovelz    时间: 2018-10-20 18:40
谢谢 正需要一个字典用
作者: lianxing11    时间: 2018-10-24 22:00
大佬能做成模块吗
作者: 视频会员    时间: 2018-11-8 10:58
哈希表有没有更新?我觉得你这个非常好用,有新版的可以给我下吗?
作者: 5182235367    时间: 2018-11-8 11:32
Meow 发表于 2018-11-8 10:58
哈希表有没有更新?我觉得你这个非常好用,有新版的可以给我下吗?

有是有,懒的发而已。。
作者: 视频会员    时间: 2018-11-8 11:53
5182235367 发表于 2018-11-8 11:32
有是有,懒的发而已。。

大神 大神 给我一下,加个qq 你这个很好用的
作者: 5182235367    时间: 2018-11-8 17:38
最新版本地址:https://125.confly.eu.org/forum.php?mod=viewthread&tid=14261124&extra=
作者: 5182235367    时间: 2018-11-8 17:38
Meow 发表于 2018-11-8 11:53
大神 大神 给我一下,加个qq 你这个很好用的

https://125.confly.eu.org/forum.php?mod=viewthread&tid=14261124&extra=
作者: tdutwftc    时间: 2018-12-9 13:50
啥情况,收藏收藏
作者: HsnoGod    时间: 2018-12-31 23:06
zaikanyixia..
作者: tianxi    时间: 2019-1-1 16:18
v为什么和 tool.chinaz.com/tools/hash.aspx 取得的sha256不一样呢
作者: 5182235367    时间: 2019-1-1 19:05
tianxi 发表于 2019-1-1 16:18
v为什么和 tool.chinaz.com/tools/hash.aspx 取得的sha256不一样呢

。。为什么要一样
我是反算取正取余
作者: w4071248    时间: 2019-1-3 19:49
666 谢谢大佬
作者: Chrismk    时间: 2019-8-18 19:20

666 谢谢大佬
作者: qq85668684    时间: 2020-2-16 14:57
大神 大神 给我一下,加个qq 你这个很好用的
作者: carmen9804    时间: 2020-9-20 19:29


666 谢谢大佬
作者: 刘教练    时间: 2020-10-3 15:02
正好用到
作者: 15339587789    时间: 2020-11-21 11:13
牛X牛X牛X牛X牛X牛X牛X牛X牛X牛X
作者: 15339587789    时间: 2020-11-21 11:22
牛得很牛得很牛得很牛得很牛得很牛得很牛得很牛得很牛得很牛得很牛得很牛得很
作者: wyyidfuck    时间: 2021-3-24 02:27
666666666666666666
作者: wyyidfuck    时间: 2021-3-24 02:28
66666666666666666666666666
作者: yundou123    时间: 2021-7-12 12:45
666666666666666666
作者: 走一回    时间: 2021-8-30 16:28
具体怎么用,能讲讲吗?
作者: 18972243344    时间: 2022-2-28 12:00
66666666666666666666666666666666666666666666666666666
作者: 18972243344    时间: 2022-2-28 13:00
666666666666666666666666666666666666666666666666666
作者: woaihualaoshi    时间: 2023-7-17 18:45
6666666非常感谢
作者: woaihualaoshi    时间: 2023-7-18 15:47
好东西!就是不懂怎么应用
作者: freeocean    时间: 2023-8-9 03:49
赠人玫瑰手有余香
作者: zifeiyu    时间: 2023-9-26 14:00
66666666666666666666666
作者: 風唲    时间: 2023-12-16 11:37
66666666666666666666666666
作者: 風唲    时间: 2023-12-16 11:38
666666666666666666666666666666666666666666666666666666666666666
作者: 杨明煜    时间: 2024-6-6 19:52
感谢,感谢........
作者: yangyzyy    时间: 2024-7-30 12:22
感谢,感谢........
作者: xuanyuanhuangdi    时间: 2024-10-18 16:21
赠人玫瑰手有余香
作者: xuanyuanhuangdi    时间: 2024-10-18 16:21
谢谢楼主的分享
作者: xzc1215    时间: 2024-12-2 19:16
感谢分享学习学习
作者: 花里胡哨之胡哨    时间: 2024-12-13 22:39
感谢分享,很给力!~
作者: 错别字    时间: 2024-12-29 14:44
感谢分享




欢迎光临 精易论坛 (https://125.confly.eu.org/) Powered by Discuz! X3.4