精易论坛

标题: 转个汇编取文本长度的源码.速度可能不好再快了 [打印本页]

作者: jr21066    时间: 2018-10-5 19:15
标题: 转个汇编取文本长度的源码.速度可能不好再快了
易论坛发现的.这是地址:
http://bbs.eyuyan.com/read.php?tid=407995


这是国人翻译后的原帖
https://bbs.pediy.com/thread-229243.htm


附件是已经转换参数地址的.也是易论坛原帖下载的.
看雪论坛的帖有解释.推荐看下




  
子程序名返回值类型公开备 注
strlen整数型 取文本长度,来自 心冷、鱼儿 改写 https://bbs.pediy.com/thread-229243.htm
参数名类 型参考可空数组备 注
str文本型
置入代码 ({ 139, 69, 8, 139, 0, 131, 248, 0, 116, 71, 82, 87, 141, 80, 3, 139, 56, 131, 192, 4, 141, 143, 255, 254, 254, 254, 247, 215, 33, 249, 129, 225, 128, 128, 128, 128, 117, 23, 139, 56, 131, 192, 4, 141, 143, 255, 254, 254, 254, 247, 215, 33, 249, 129, 225, 128, 128, 128, 128, 116, 210, 247, 193, 128, 128, 0, 0, 117, 6, 193, 233, 16, 131, 192, 2, 208, 225, 25, 208, 95, 90, 201, 194, 4, 0 })
' mov eax,dword [ebp+08h]
' mov eax,dword [eax]
' cmp eax,0
' je exit
' push edx
' push edi
' lea edx,dword [eax+03h]
' label_b:
' mov edi,dword [eax]
' add eax,4
' lea ecx,dword [edi-01010101h]
' not edi
' and ecx,edi
' and ecx,80808080h
' jnz nxt
' mov edi,dword [eax]
' add eax,4
' lea ecx,dword [edi-01010101h]
' not edi
' and ecx,edi
' and ecx,80808080h
' jz label_b
' nxt:
' test ecx,00008080h
' jnz label_f
' shr ecx,16
' add eax,2
' label_f:
' shl cl,1
' sbb eax,edx
' pop edi
' pop edx
' exit:
' leave
' ret 04h
返回 (0)

strlen.e

4.24 KB, 下载次数: 35, 下载积分: 精币 -2 枚


作者: 一瓶矿泉水    时间: 2018-10-5 19:49
用在web服务器上URL解析,看看效率能有多大的提升。
作者: jr21066    时间: 2018-10-5 20:17
一瓶矿泉水 发表于 2018-10-5 19:49
用在web服务器上URL解析,看看效率能有多大的提升。

试过了.比传统的汇编单字节快三倍.如果指令没用对.可能还要再快一些.
作者: 一瓶矿泉水    时间: 2018-10-5 20:47
jr21066 发表于 2018-10-5 20:17
试过了.比传统的汇编单字节快三倍.如果指令没用对.可能还要再快一些.

那就满足了,效率飞起来
作者: cf2006a    时间: 2018-10-5 22:18
很早就有人发过了,不过实现原理还是没能理解😊
作者: jr21066    时间: 2018-10-5 22:36
cf2006a 发表于 2018-10-5 22:18
很早就有人发过了,不过实现原理还是没能理解😊

看雪的帖子是有说明的.

只有0这个特殊的数.所有位是0.但在减一后全部都是1.and的结果是0
通过这方法来一次检测四字节.
作者: cf2006a    时间: 2018-10-6 21:04
jr21066 发表于 2018-10-5 22:36
看雪的帖子是有说明的.

只有0这个特殊的数.所有位是0.但在减一后全部都是1.and的结果是0

不是太明白
作者: cf2006a    时间: 2018-10-7 14:44
jr21066 发表于 2018-10-5 22:36
看雪的帖子是有说明的.

只有0这个特殊的数.所有位是0.但在减一后全部都是1.and的结果是0

优化了下 把一样的代码删除掉


{ 139, 69, 8, 139, 0, 141, 80, 3, 139, 56, 131, 192, 4, 141, 143, 255, 254, 254, 254, 247, 215, 33, 249, 129, 225, 128, 128, 128, 128, 117, 2, 116, 231, 247, 193, 128, 128, 0, 0, 117, 6, 193, 233, 16, 131, 192, 2, 208, 225, 25, 208, 201, 194, 4, 0 }
作者: jr21066    时间: 2018-10-7 15:08
cf2006a 发表于 2018-10-7 14:44
优化了下 把一样的代码删除掉

没有多余的代码吧.结果你测试了没
作者: cf2006a    时间: 2018-10-7 21:37
本帖最后由 cf2006a 于 2018-10-8 06:47 编辑
jr21066 发表于 2018-10-7 15:08
没有多余的代码吧.结果你测试了没


听说这个更快,还没试过!!!!




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