为了账号安全,请及时绑定邮箱和手机立即绑定

按位不至于没有 ffffffff 怎么办

按位不至于没有 ffffffff 怎么办

Go
繁星淼淼 2022-04-26 19:43:22
当按位不做时,得到很多 ffffffff。如何正确做?    space := "    "    str := "12345678999298765432179.170.184.81"    sp := len(str) % 4    if sp > 0 {        str = str + space[0:4-sp]    }    fmt.Println(str, len(str))    hx := hex.EncodeToString([]byte(str))    ln := len(hx)    a, _ := strconv.ParseUint(hx[0:8], 16, 0)    for i := 8; i < ln; i += 8 {        b, _ := strconv.ParseUint(hx[i:i+8], 16, 0)        a = a ^ b    }    xh := strconv.FormatUint(^a, 16)    fmt.Println(xh)输出 ffffffffc7c7dbcb我只需要 c7c7dbcb
查看完整描述

1 回答

?
哈士奇WWW

TA贡献1799条经验 获得超6个赞

您获得了很多领先优势ff,因为您的a数字实际上只是 32 位“大”,但在 64 位uint64值“内”使用。(您正在处理具有 8 个十六进制数字 = 4 字节数据 = 32 位的数字。)它有 4 个前导 0 字节,当取反时将变成ff. 您可以通过以下方式验证这一点:

fmt.Printf("a %#x\n",a)

输出:

a 0x38382434

要摆脱那些领先ff,将结果转换为uint32

xh := strconv.FormatUint(uint64(uint32(^a)), 16)
fmt.Println(xh)

(转换回uint64是因为strconv.FormatUint()期望/需要uint64。)

这输出:

c7c7dbcb

另一种选择是应用0xffffffff位掩码:

xh = strconv.FormatUint(^a&0xffffffff, 16)
fmt.Println(xh)

另请注意,您可以使用fmt.Printf()(或者fmt.Sprintf()如果您需要将其作为 a string)打印它,您可以在其中指定%08x动词,如果输入具有超过 3 个前导 0 位(因此strconv.FormatUint()不会添加前导十六进制零),该动词还会添加前导零:

fmt.Printf("%08x", uint32(^a))

这输出相同。试试Go Playground上的示例。


查看完整回答
反对 回复 2022-04-26
  • 1 回答
  • 0 关注
  • 142 浏览
慕课专栏
更多

添加回答

举报

0/150
提交
取消
微信客服

购课补贴
联系客服咨询优惠详情

帮助反馈 APP下载

慕课网APP
您的移动学习伙伴

公众号

扫描二维码
关注慕课网微信公众号