我正在尝试编写一个 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)
1 回答
- 1 回答
- 0 关注
- 158 浏览
添加回答
举报
0/150
提交
取消