Jquery中文网 www.jquerycn.cn
Jquery中文网 >  脚本编程  >  C语言  >  正文 Hash算法(KetamaHash)的c#实现

Hash算法(KetamaHash)的c#实现

发布时间:2018-11-07   编辑:www.jquerycn.cn
jquery中文网为您提供Hash算法(KetamaHash)的c#实现等资源,欢迎您收藏本站,我们将为您提供最新的Hash算法(KetamaHash)的c#实现资源
<script>ec(2);</script>
<blockquote>

public class hashalgorithm
{
    public static long hash(byte[] digest, int ntime)
    {
        long rv = ((long)(digest[3 ntime * 4] & 0xff) << 24)
                | ((long)(digest[2 ntime * 4] & 0xff) << 16)
                | ((long)(digest[1 ntime * 4] & 0xff) << 8)
                | ((long)digest[0 ntime * 4] & 0xff);

        return rv & 0xffffffffl; /* truncate to 32-bits */
    }

    /**
     * get the md5 of the given key.
     */
    public static byte[] computemd5(string k)
    {
        md5 md5 = new md5cryptoserviceprovider();
      
        byte[] keybytes = md5.computehash(encoding.utf8.getbytes(k));
        md5.clear();
        //md5.update(keybytes);
        //return md5.digest();
        return keybytes;
    }
}


public class ketamanodelocator
{
    //原文中的java类treemap实现了comparator方法,这里我图省事,直接用了net下的sortedlist,其中comparer接口方法)
    private sortedlist<long, string> ketamanodes = new sortedlist<long, string>();
    private hashalgorithm hashalg;
    private int numrehttp://www.111cn.net
            var tailmap = from coll in ketamanodes
                          where coll.key > hash
                          select new { coll.key };
            if (tailmap == null || tailmap.count() == 0)
                key = ketamanodes.firstordefault().key;
            else
                key = tailmap.firstordefault().key;
        }
        rv = ketamanodes[key];
        return rv;
   

</blockquote>

您可能感兴趣的文章:
MD5 hash algorithm function
Drupal中如何配置及利用Memcache的hash策略
关于hashchangebroker和statehashable的补充文档
VBS 添加右键以计算文件MD5值的代码(图文)
php实现sql防止注入的几种方法
让网页跳转到指定位置的jquery代码非书签
js 数组去除重复项的五种方法
shell四则运算(整数及浮点数)的方法介绍
LVS调度算法和三种工作模式
javascript 实现加法运算详解

[关闭]