uint16 到 xx.x 浮点数——最快的算法?

uint16 to xx.x float -- fastest algorithm?

我从温度传感器接收数据,数据格式为两个字节,是固定宽度浮点数据的二进制编码。编码方案可以在下面table:

中演示
| temperature | hexadecimal | int16 |
| 0.1 *F      | 0x00 0x01   | 01    |
| 10.0 *F     | 0x00 0x64   | 100   |

为了重建浮点值,我写了下面的小程序:

package main

import (
    "encoding/binary"
    "fmt"
    "strconv"
)

func main() {
    b1 := byte(0x02)
    b2 := byte(0xBC)
    b := []byte{b1, b2}
    intgr := binary.BigEndian.Uint16(b)
    str := fmt.Sprint(intgr)
    l := len(str)
    front := str[:l-1]
    decimal := str[l-1:]
    str = fmt.Sprintf("%v.%v", front, decimal)
    float, _ := strconv.ParseFloat(str, 64)
    fmt.Println(float)
}

但是对我的需求来说有点太慢了,我想这是因为我用过Sprint/Sprintf。是否有更快(也许更清洁)的算法来执行此操作?

将字节转换为数字并除以 10:

b := []byte{0x02, 0xBC}
f := float64(binary.BigEndian.Uint16(b)) / 10.0

反向转换为:

p := make([]byte, 2)
binary.BigEndian.PutUint16(p, uint16(math.Round(f*10.0)))

要处理负数,在转换为 float 之前将 uint16 转换为 int16:

f := float64(int16(binary.BigEndian.Uint16(p))) / 10.0