猿问

int64 的可变长度二进制补码

我正在尝试编写一个 Go 程序来解析 ans.1 BER 二进制补码整数编码。但是,整数可以具有 1、2、3 或 4 字节长度的编码(取决于其大小)。


根据规范(http://www.itu.int/ITU-T/studygroups/com17/languages/X.690-0207.pdf)最左边的位总是补码。


什么是干净的方法来做到这一点?


func ParseInt(b []byte) (int64, error) {

    switch len(b) {

    case 1:

        // this works

        return int64(b[0]&0x7f) - int64(b[0]&0x80), nil

    case 2:

        // left most byte of b[0] is -32768

    case 3:

        // left most byte of b[0] is -8388608

    case 4:

        // left most byte of b[0] is -2147483648 (and so on for 5, 6, 7, 8)

    case 5:

    case 6:

    case 7:

    case 8:

    default:

        return 0, errors.New("value does not fit in a int64")

    }

}



ParseInt([]byte{0xfe})       // should return (-2, nil)

ParseInt([]byte{0xfe, 0xff}) // should return (-257, nil)

ParseInt([]byte{0x01, 0x00}) // should return (256, nil)


慕工程0101907
浏览 160回答 1
1回答
随时随地看视频慕课网APP

相关分类

Go
我要回答