使用签名数据进行逐位解包
Bitwise unpacking using signed data
本文关键字:数据 更新时间:2023-10-16
我已经尝试了一段时间的pack&将一些字符解压缩为一个整数。虽然有一些话题与这个问题有关,但我的问题与签名轮班有关。我没有破解签名值的"窍门",即:
char c1 = -119;
char c2 = 26;
// pack
int packed = (unsigned char)c1 | (c2 << 8);
// unpack
c1 = packed >> 0;
c2 = packed >> 8;
// printf(c1, c2) -> Unpacked data: -119 | 26
这与预期一样有效,但当我尝试打包更多数据时,即:
char c0 = -42;
char c1 = -119;
char c2 = 26;
// pack
int packed = (unsigned char)c0 | (unsigned char)(c1 << 8) | (c2 << 16);
// unpack
c0 = packed >> 0;
c1 = packed >> 8;
c2 = packed >> 16;
// printf -> Unpacked data: -42 | 0 | 26
c1值丢失。我想这与有关,符号位被移到了高阶位置。
我如何才能取回c1值?
提前谢谢。
在将c1
移出该类型的范围后,将其强制转换为unsigned char
,因此强制转换的结果为零。你应该在换班前做演员:
int packed = (unsigned char)c0 | ((unsigned char)c1 << 8) | (c2 << 16);
(unsigned char)(c1 << 8)
这将
- 移位错误的(符号扩展(值
- 将结果修剪为8位(产生0(
您不想要这些,所以应该使用((unsigned char)c1 << 8)
。
一些int
是16位。要使此代码可移植,请使用int32_t
。实现这一点的正确方法(如果有点偏执的话(是:
int32_t packed = ((uint8_t)c0) | (((uint8_t)c1)<<8) | (((uint8_t)c2) << 16);
我也倾向于按相反的顺序列出这些字符,所以哪些字符成为最重要和最不重要的字节更自然。
相关文章:
- 防止主数据类型C++的隐式转换
- 用于访问容器<T>数据成员的正确 API
- 嵌套在类中时无法设置成员数据
- 使用流处理接收到的数据
- 静态数据成员的问题-修复链接错误会导致编译器错误
- 处理小于cpu数据总线的数据类型.(c++转换为机器代码)
- 在cuda线程之间共享大量常量数据
- C++将文本文件中的数据读取到结构数组中
- 如何在C++中序列化结构数据
- 在C++中打印指向不同基元数据类型的指针的内存地址
- 通过套接字[TCP]传输数据 如何在C / C ++中打包多个整数并使用send() recv()传输数据
- 在c代码之间共享数据的最佳方式
- 链表,反向函数,数据结构
- 数据成员SFINAE的C++17测试:gcc vs clang
- C++浮点数据类型和字符串数据类型无法子到模板函数中
- 如何对点云数据进行排序
- 从矢量<无符号字符>转换为字符* 包括垃圾数据
- 尝试通过OCI例程从Oracle获取blob数据,但出现错误:ORA-01008:并非所有变量都绑定
- Cuda C++:设备上的Malloc类,并用来自主机的数据填充它
- 在运行时处理类型擦除的数据-如何不重新发明轮子