打开APP
userphoto
未登录

开通VIP,畅享免费电子书等14项超值服

开通VIP
Delphi:两个高效的哈希函数
function BKDRHash(buf: Pointer; count: Integer) : Cardinal; assembler;  
asm  
        PUSH  EBX;  
        XOR   EBX, EBX  
        MOV   ECX, EAX  
        XOR   EAX, EAX  
@LOOP:  
        TEST  EDX, EDX  
        JZ    @EXIT  
        MOV   BL,  [ECX]  
        IMUL  EAX, 131 
        ADD   EAX, EBX  
        INC   ECX  
        DEC   EDX  
        JMP   @LOOP  
@EXIT:  
        POP   EBX  
//----------------------------  
// Pascal:  
//  
//  Result := 0;  
//  while count > 0 do  
//  begin  
//    Result := (Result * 131) + PByte(buf)^;  
//    Inc(PByte(buf));  
//    Dec(count);  
//  end;  
end;  
function DJBHash(buf: Pointer; count: Integer) : Cardinal; assembler;  
asm  
        PUSH  EDI  
        PUSH  EBX  
        XOR   EBX, EBX  
        MOV   ECX, EAX  
        MOV   EAX, 5381 
@LOOP:  
        TEST  EDX, EDX  
        JZ    @EXIT  
        MOV   EDI, EAX  
        SHL   EDI, 5 
        ADD   EAX, EDI  
        MOV   BL, [ECX]  
        ADD   EAX, EBX  
        INC   ECX  
        DEC   EDX  
        JMP   @LOOP  
@EXIT:  
        POP   EBX  
        POP   EDI  
//----------------------------  
// Pascal:  
//  
//  Result := 5381;  
//  while count > 0 do  
//  begin  
//    Result := ((Result shl 5) + Result) + PByte(buf)^;  
//    Inc(PByte(buf));  
//    Dec(count);  
//  end;  
end; 
本站仅提供存储服务,所有内容均由用户发布,如发现有害或侵权内容,请点击举报
打开APP,阅读全文并永久保存 查看更多类似文章
猜你喜欢
类似文章
AT&T汇编与Intel汇编
Let's Understand: Setjmp()/longjmp()
OllyDBG序列号追踪小记
360安全卫士hookport.sys简单逆向——KiFastCallEntry挂钩
PECompact 2.x -> Jeremy Collake完美脱壳去校验 - 『 我为...
project:useful_code_slice:boyer_moore_algorithm [Xie Yubo‘s Wiki]
更多类似文章 >>
生活服务
热点新闻
分享 收藏 导长图 关注 下载文章
绑定账号成功
后续可登录账号畅享VIP特权!
如果VIP功能使用有故障,
可点击这里联系客服!

联系客服