分表实现-代码片

两个方法,一个是得到结点的方法,一个是算法的方法

 /**
     * 得到应当路由到的结点
     */
    public static String getServer(SortedMap<Integer, String> nodes, String key) {
        // 得到带路由的结点的Hash值
        int hash = SubTableHash.getHash(key);
        // 得到大于该Hash值的所有Map
        SortedMap<Integer, String> subMap =
                nodes.tailMap(hash);
        String virtualNode = "";
        if (subMap.size() == 0) {
            //超出最大值 取第一个
            virtualNode = nodes.get(nodes.firstKey());
        } else {
            // 第一个Key就是顺时针过去离node最近的那个结点
            Integer i = subMap.firstKey();
            virtualNode = subMap.get(i);
        }
        // 返回对应的虚拟节点名称
        return virtualNode;
    }
public static int getHash(String str) {
        final int p = 16777619;
        int hash = (int)2166136261L;
        for (int i = 0; i < str.length(); i++) {
            hash = (hash ^ str.charAt(i)) * p;
        }
        hash += hash << 13;
        hash ^= hash >> 7;
        hash += hash << 3;
        hash ^= hash >> 17;
        hash += hash << 5;

        // 如果算出来的值为负数则取其绝对值
        if (hash < 0) {
            hash = Math.abs(hash);
        }
        return hash % 128;
    }

思路基本能懂,但是上面的算法叫HASHFNV优化后的32位的算法,是不懂。问了几个数学的同学,让我用代入法试试,我的疑惑不是这个结果,我试着理解理解吧,求指点。详细资料放资料库吧。

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值