mongodb mongo-go-driver Decimal128 中的高值和低值是多少以及如何使用它们创建新的小数
What are the high and low values in mongodb mongo-go-driver Decimal128 and how to use them to create a new decimal
The GO driver for MongoDB has a 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.h
和Decimal128.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()
方法的实现以了解详细信息。
如您所见,"individual" 低值和高值与表示的浮点数没有直接关联,而是按上述方式处理它们的 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}
The GO driver for MongoDB has a 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.h
和Decimal128.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()
方法的实现以了解详细信息。
如您所见,"individual" 低值和高值与表示的浮点数没有直接关联,而是按上述方式处理它们的 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}