从大端转换为小端 C++
convert from big to little endian c++
我正在做一个家庭作业,打印出int
和float
的大端和小端值。我在转换为小端序时遇到问题。
这是我的代码
void convertLitteE(string input)
{
int theInt;
stringstream stream(input);
while(stream >> theInt)
{
float f = (float)theInt;
printf("n%dn",theInt);
printf("int: 0x");
printLittle((char *) &theInt, sizeof(theInt));
printf("nfloat: 0x");
printLittle((char *) &f, sizeof(f));
printf("nn");
}
}
void printLittle(char *p, int nBytes)
{
for (int i = 0; i < nBytes; i++, p++)
{
printf("%02X", *p);
}
}
当输入为 12 时,我得到我所期望的
output:
int: 0x0C000000
float: 0x00004041
但是当输入为 1234 时
output:
int: 0xFFFFFFD20400000
float: 0x0040FFFFFFF9A44
但我会期待
int : 0xD2040000
float: 0x00409A44
当我逐步完成for
循环时,我可以看到似乎有垃圾值的位置,然后它打印了所有F
,但我不知道为什么。我已经尝试了很多不同的方法,但我无法让它工作。
任何帮助将不胜感激。
显然在您的系统上,char
是有符号的8位类型。 使用无符号的 8 位字节,1234 的 4 字节小端表示形式将0xd2, 0x04, 0x00, 0x00
。 但是,当在大多数系统上解释为已签名的char
时,0xd2
变得-0x2e
。
然后调用 printf
将该char
提升到具有值 -0x2e
的int
,然后printf
(不是很类型安全)在您传递int
的unsigned int
中读取。 这是未定义的行为,但在大多数系统上,它将与 static_cast
相同,因此您在尝试打印第一个字节时会得到0xFFFFFFD2
的值。
如果您坚持在这些函数中使用unsigned char
而不是char
,则可以避免此特定问题。
(但正如@jogojapan指出的那样,这整个方法根本不是可移植的。
相关文章:
- 防止主数据类型C++的隐式转换
- 模板参数替换失败,并且未完成隐式转换
- 努力将整数转换为链表。不知道我在这里做错了什么
- HEX值到wchar_t字符(UTF-8)的转换
- lambda参数转换为constexpr技巧,然后获取带链接的数组
- 将 Qvector<uint8_t> 转换为 QString
- 如何在cuSparse中使用cusparseXcoo2csr从coo转换为csc
- 有关插入适配器的错误。[错误]请求从 'back_insert_iterator<vector<>>' 类型转换为非标量类型
- 在c++中使用nlohmann从类到json的转换
- 从"int*"强制转换为"unsigned int"会丢失精度错误
- 将Integer转换为4字节的unsined字符矢量(按大端字节顺序)
- 处理小于cpu数据总线的数据类型.(c++转换为机器代码)
- 如何使用OpenCV将RBG图像转换为HSV,并将H、S和V值保存为C++中的3个独立图像
- 复制列表初始化的隐式转换的等级是多少
- 正在将指针转换为范围
- 如何防止 c++ 在从浮点型转换为双精度型(不适用于 IO)时添加额外的小数?
- 将"打开的CV图像"中的"颜色"转换为整数格式
- 是否可以从int转换为enum类类型
- 了解 GLM- openGL 中的相机转换
- 将无符号char*转换为std::istream*C++