iis服务器助手广告
返回顶部
首页 > 资讯 > 后端开发 > GO >更好地理解 Kademlia 的 XOR 整数度量
  • 532
分享到

更好地理解 Kademlia 的 XOR 整数度量

2024-04-04 23:04:30 532人浏览 泡泡鱼
摘要

一分耕耘,一分收获!既然都打开这篇《更好地理解 Kademlia 的 XOR 整数度量》,就坚持看下去,学下去吧!本文主要会给大家讲到等等知识点,如果大家对本文有好的建议或者看到有不足之处,非常欢迎

一分耕耘,一分收获!既然都打开这篇《更好地理解 Kademlia 的 XOR 整数度量》,就坚持看下去,学下去吧!本文主要会给大家讲到等等知识点,如果大家对本文有好的建议或者看到有不足之处,非常欢迎大家积极提出!在后续文章我会继续更新golang相关的内容,希望对大家都有所帮助!

问题内容

我正在尝试更好地掌握 kademlia 的 xor 距离度量,因此我编写了一个小虚拟程序来尝试更好地理解。我在这里也没有使用 160 位数字作为密钥,而是使用某些用户标识符的 sha256 哈希值。

这是我的异或距离函数。这或多或少是正确的吗?我对每个字节进行异或 - 将其附加到缓冲区 rawbytes 并将该字节缓冲区转换为整数。

func XorDistance(node string, otherNode string) uint64 {
    var rawBytes [32]byte
    for i := 0; i < 32; i++ {
        rawBytes[i] = node[i] ^ otherNode[i]
    }
    distance, _ := binary.Uvarint(rawBytes[:])
    return distance
}


解决方案


这是不正确的,因为

  • binary.uvarint()只能解码64位以内的数字,而你的rawbytes是256位
  • “varint”编码(如 https://Golang.org/src/encoding/binary/varint.go 中所述)基本上与原始字节不兼容。

您必须使用 math/big 包才能进行此类使用。这是我对您的代码片段的修改版本:

func xorDistance(node string, otherNode string) *big.Int {
    var rawBytes [32]byte
    for i := 0; i < 32; i++ {
        rawBytes[i] = node[i] ^ otherNode[i]
    }
    return big.NewInt(0).SetBytes(rawBytes[:])
}

以上就是《更好地理解 Kademlia 的 XOR 整数度量》的详细内容,更多关于的资料请关注编程网公众号!

您可能感兴趣的文档:

--结束END--

本文标题: 更好地理解 Kademlia 的 XOR 整数度量

本文链接: https://www.lsjlt.com/news/596415.html(转载时请注明来源链接)

有问题或投稿请发送至: 邮箱/279061341@qq.com    QQ/279061341

本篇文章演示代码以及资料文档资料下载

下载Word文档到电脑,方便收藏和打印~

下载Word文档
猜你喜欢
软考高级职称资格查询
编程网,编程工程师的家园,是目前国内优秀的开源技术社区之一,形成了由开源软件库、代码分享、资讯、协作翻译、讨论区和博客等几大频道内容,为IT开发者提供了一个发现、使用、并交流开源技术的平台。
  • 官方手机版

  • 微信公众号

  • 商务合作