二进制补码和 fmt.Printf 二进制输出
当计算机使用二进制补码表示有符号整数时,像 -5 这样的值存储为位模式“1111 1011”。但是,当尝试使用 fmt.Printf 打印此二进制表示形式时,如下所示:
var i int8 = -5
fmt.Printf("%b", i)
输出意外显示“-101”。为什么会发生这种情况,内部是否使用了二进制补码?
二进制格式的问题
差异在于 fmt.Printf 处理二进制格式的方式。当格式化负符号整数时,它会将其转换为正值,然后在格式化字符串前附加“-”号。
查看fmt.Printf的源代码,我们发现fmt.integer转换在格式化之前将有符号整数转换为正值:
negative := signedness == signed && a 无符号与有符号输出
为了演示这一点,请考虑以下代码:
var u uint8 = uint(i)
fmt.Printf("%b", u)
这里,我们在打印之前将 i 转换为无符号整数。这次,输出正确显示“11111011”,这是 -5 的补码。
结论
要正确打印带符号整数的二进制表示形式,请使用fmt.Printf,我们应该首先使用无符号类型将其转换为正整数。这可确保 fmt.Printf 不会自动将值转换为负值并在前面添加“-”符号。
免责声明: 提供的所有资源部分来自互联网,如果有侵犯您的版权或其他权益,请说明详细缘由并提供版权或权益证明然后发到邮箱:[email protected] 我们会第一时间内为您处理。
Copyright© 2022 湘ICP备2022001581号-3