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

标签 mongodb go decimal mongo-go

The GO driver for MongoDB有一个Decimal128 type 是一个如下所示的结构:

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() 的实现情况详细方法。

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

例如“100.50” 的低值和高值将是:

d, err := primitive.ParseDecimal128("100.50")
fmt.Println(d, err)
fmt.Printf("%#v", d)

输出(在 Go Playground 上尝试):

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

关于mongodb - mongodb mongo-go-driver Decimal128 中的高值和低值是多少以及如何使用它们创建新的小数,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/59562936/

相关文章:

node.js - 子项的子项内的 where 子句

ruby - 试图弄清楚我应该使用什么样的关系

javascript - 使用函数的输出作为字符串变量

ruby-on-rails - 联合两个mongo结果

Go:如何获得任何 go 文件的自动完成

algorithm - 二进制到十进制(大数)

python 小数奇怪的句柄以及如何获得最接近的一位小数 float ?

facebook - 使用huandu/facebook Golang FB api时出现DecodeField错误

go - golang 中的复制并发安全吗?

mysql - 仅选择数字值的小数部分