PHP hash算法

2023-05-06,,

function myHash($str) {
        // hash(i) = hash(i-1) * 33 + str[i]
        $hash = 0;
        $s    = md5($str);
        $seed = 5;
        $len  = 32;
        
        for ($i = 0; $i < $len; $i++) {
            // (hash << 5) + hash 相当于 hash * 33
            //$hash = sprintf("%u", $hash * 33) + ord($s{$i});
            //$hash = ($hash * 33 + ord($s{$i})) & 0x7FFFFFFF;
            $hash = ($hash << $seed) + $hash + ord($s{$i});
        }

        return $hash & 0x7FFFFFFF;
    }

 for($i=1;$i<=1000000;$i++){
        $arr[$i] = (myHash($i)%10)+1;
  }
        
        var_dump(array_count_values($arr));

《PHP hash算法.doc》

下载本文的Word格式文档,以方便收藏与打印。