我正在尝试将一个字节流分配给一个结构。流正确地进入结构,因为我可以在调试窗口中看到它,但是当我尝试打印时,结构没有正确显示8byte整数值。
输出:
serial no :: 1
Timestamp :: -1541974141
userid :: 0
代码:
#include <QCoreApplication>
#pragma pack(push,1)
struct info
{
int serialno;
long long timestamp;
int userid;
};
#pragma (pop)
int main(int argc, char *argv[])
{
QCoreApplication a(argc, argv);
unsigned char arr[16];
arr[0] = 0x01;
arr[1] = 0x00;
arr[2] = 0x00;
arr[3] = 0x00;
arr[4] = 0x83;
arr[5] = 0x57;
arr[6] = 0x17;
arr[7] = 0xA4;
arr[8] = 0xF6;
arr[9] = 0x00;
arr[10] = 0x00;
arr[11] = 0x00;
arr[12] = 0x00;
arr[13] = 0x00;
arr[14] = 0x00;
arr[15] = 0x00;
info *var;
var = (info*)&arr[0];
printf("serial no :: %d\n",var->serialno);
printf("Timestamp :: %d\n",var->timestamp);
printf("userid :: %d\n",var->userid);
return a.exec();
}
答案 0 :(得分:1)
这就是为什么printf()
和朋友气馁的原因。他们不是类型安全的。 %d
打印int
。您传递的是long long
,因此printf()
的内部会将其截断为int
部分。
使用std::cout
代替,它将使用适当大小的重载:
#include <iostream>
std::cout << "serial no :: " << var->serialno << '\n';
std::cout << "Timestamp :: " << var->timestamp << '\n';
std::cout << "userid :: " << var->userid << '\n';
答案 1 :(得分:0)
阅读endianess这是因为你看到了这种行为的体系结构
在big-endian中,整数值从低地址到高地址存储在内存中。在小端系统上,反之亦然。