• 技术文章 >后端开发 >php教程

    PHP Hash算法:Times33算法代码实例_PHP

    2016-06-01 11:05:45原创675
    最近看书,里面提到了一些Hash算法。比较有印象的是Times33,当时理解不是很透测,今天写了段程序来验证了一下。
    先上代码:

    代码如下:


    <?php

    /**
    * CRC32 Hash function
    * @param $str
    * @return int
    */
    function hash32($str)
    {
    return crc32($str) >> 16 & 0x7FFFFFFF;
    }

    /**
    * Times33 Hash function
    * @param $str
    * @return int
    */
    function hash33($str)
    {
    $hash = 0;
    for($i=0; $i $hash += 33 * $hash + ord($str{$i});
    }
    return $hash & 0x7FFFFFFF;
    }


    $n = 10;

    // Test Case 1
    $stat = array();
    for($i=0; $i<10000; $i++){
    $str = substr(md5(microtime(true)), 0, 8);
    $p = hash32($str) % $n;
    if(isset($stat[$p])){
    $stat[$p]++;
    }else{
    $stat[$p] = 1;
    }
    }
    print_r($stat);

    // Test Case 2
    $stat = array();
    for($i=0; $i<10000; $i++){
    $str = substr(md5(microtime(true)), 0, 8);
    $p = hash33($str) % $n;
    if(isset($stat[$p])){
    $stat[$p]++;
    }else{
    $stat[$p] = 1;
    }
    }
    print_r($stat);

    以上有两个测试用例。第一个,用CRC32的方法;第二个是Times33的算法实现。

    效果:

    结果分布,两种算法不相上下(估计是数据源的问题,md5只有0-f)。也有文章说CRC32的分布更均匀(参考链接:)
    但耗费时间,CRC32比Times33快将近一倍。

    为什么是33?

    即是素数(质数),也是奇数。除了33,还有131, 1313, 5381等。PHP内置的Hash函数用的是5381,在“鸟哥”的一篇博文中也有提到。

    声明:本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn核实处理。
    专题推荐:PHP Hash 算法 Times33
    上一篇:php实现修改新闻时删除图片的方法_PHP 下一篇:PHP stream_context_create()函数的使用示例_PHP
    千万级数据并发解决方案

    相关文章推荐

    • PHP编码规范的深入探讨_PHP• php设计模式 Bridge (桥接模式)_PHP• rephactor 优秀的PHP的重构工具_PHP• php 数组使用详解 推荐_PHP• php笔记之常用文件操作_PHP
    1/1

    PHP中文网