登录
首页 >  Golang >  Go问答

mongodb mongo-go-driver Decimal128 中的高值和低值是多少以及如何使用它们创建新的小数

来源:stackoverflow

时间:2024-03-17 11:18:28 406浏览 收藏

MongoDB 的 Go 驱动程序中,`decimal128` 类型由两个 64 位无符号整数 `h` 和 `l` 组成,它们共同表示一个 128 位小数。`h` 包含符号位、保留位和指数,而 `l` 存储有效数字。这种表示类似于 IEEE 754 四精度浮点数格式,但略有不同。

问题内容

mongodb 的 go 驱动程序有一个 decimal128 类型,它是一个如下所示的结构:

type decimal128 struct {
    h, l uint64
}

根据文档,h 和 l 是 uint64 的高值和低值。这两个值代表什么?假设我想创建一个 decimal128,转换为字符串时将等于 "100.50"。使用下面的函数,h 和 l 的值是多少。

func newdecimal128(h, l uint64) decimal128 {
    return decimal128{h: h, l: l}
}

我总是被迫解析这样的字符串 d, _ := primitive.parsedecimal128("100.50") 而不是

d := primitive.NewDecimal128(h, l)

创建一个新的 decimal128 只是因为我不明白如何使用高值和低值来导出十进制值。


解决方案


decimal128.hdecimal128.l 都是 uint64 类型,都是 64 位,加起来为 128 位。

| decimal128.h bits   || decimal128.l bits   |
63...            ....0  63...           ....0

mongo-go 的 decimal128 实现与 IEEE 754 quadruple-precision floating-point format 类似/接近,但有一些细微差别。 h 的最高位是符号位,然后有 2 位被忽略,然后是 14 位指数和 111 位有效数。符号位旁边的后续 5 位是特殊的,如果它们的值为 0x1f,则表示 decimal128 值表示 nan(不是数字),如果它们的值为 0x1e,则该值表示正无穷大或负无穷大(取决于符号)位)。

查看 Decimal128.BigInt() 方法的实现以了解详细信息。

如您所见,“单独的”低值和高值与所表示的浮点数没有直接相关性,而是按上述方式处理它们的 128 位。

例如"100.50" 的低值和高值将是:

d, err := primitive.parsedecimal128("100.50")
fmt.println(d, err)
fmt.printf("%#v", d)

输出(在 Go Playground 上尝试):

100.50 
primitive.Decimal128{h:0x303c000000000000, l:0x2742}

今天带大家了解了的相关知识,希望对你有所帮助;关于Golang的技术知识我们会一点点深入介绍,欢迎大家关注golang学习网公众号,一起学习编程~

声明:本文转载于:stackoverflow 如有侵犯,请联系study_golang@163.com删除
相关阅读
更多>
最新阅读
更多>
课程推荐
更多>