我尝试使用Go获取KiB, MiB, ..., ZiB, Yib
的值KibiByte, MebiByte, ..., ZebiByte, YobiByte
。
我在Golang的代码是:
package main
import (
"fmt"
)
func main() {
s := []string{"KiB", "MiB", "GiB", "TiB", "PiB", "EiB", "ZiB", "YiB"}
for k,v := range(s) {
fmt.Printf("%s: %v\n", v, 1 << uint64(10 * (k+1)))
}
}
但是,ZiB and YiB
的值溢出了Go uint64
,这就是为什么我有这个输出:
KiB: 1024
MiB: 1048576
GiB: 1073741824
TiB: 1099511627776 // exceeds 1 << 32
PiB: 1125899906842624
EiB: 1152921504606846976
ZiB: 0 // exceeds 1 << 64
YiB: 0 // exceeds 1 << 64
否则,在此代码中使用Python3
中的相同移位逻辑:
a = ["KiB", "MiB", "GiB", "TiB", "PiB", "EiB", "ZiB", "YiB"]
for k,v in enumerate(a):
print("{}: {}".format(v, 1 << (10 *(k+1))))
输出正确,如下面的输出:
KiB: 1024
MiB: 1048576
GiB: 1073741824
TiB: 1099511627776
PiB: 1125899906842624
EiB: 1152921504606846976
ZiB: 1180591620717411303424
YiB: 1208925819614629174706176
那么,我如何绕过Go uint64
限制并使用移位整数来获取正确的值,就像我可以通过使用Python移位整数得到的那样。
感谢。
答案 0 :(得分:9)
您无法使用原始uint64需要超过64位的数字。 Python具有任意精度整数,要在Go中获得相同的结果,您需要使用math/big
包。
s := []string{"KiB", "MiB", "GiB", "TiB", "PiB", "EiB", "ZiB", "YiB"}
one := big.NewInt(1)
for k, v := range s {
fmt.Printf("%s: %v\n", v, new(big.Int).Lsh(one, uint(10*(k+1))))
}