从FIFO读的信息有误:字节对齐 问题与解决
typedef enmu{
OT_UNKNOW = -1,
OT_ADD =0
}OTType;
typedef struct {
pid_t pid;
OTType OT;
}MessageClient;
typedef struct {
MessageClient MC;
char ResourceID[ID_SIZE];//ID_SIZE = 49
int result;
}ResultInfo;
OT_UNKNOW = -1,
OT_ADD =0
}OTType;
typedef struct {
pid_t pid;
OTType OT;
}MessageClient;
typedef struct {
MessageClient MC;
char ResourceID[ID_SIZE];//ID_SIZE = 49
int result;
}ResultInfo;
sizeof(ResultInfo) = 64 =8 +49+4+3(padding)
MC 放于前面1-8个字节,ResourceID排在9-57个字节 , result 排在58-61, 62-64 是padding。
read(fd, &mc1, sizeof(MessageClient));//fine
read(fd, &resourceID1, sizeof(ID_SIZE));//fine
read(fd, &result1, sizeof(int));// NOT fine
read(fd, &resourceID1, sizeof(ID_SIZE));//fine
read(fd, &result1, sizeof(int));// NOT fine
最后一次读的有误。读出的不是传的1 or 0 。而是较大的数值。
估计是读取最后一次时,读的是58-61。但多次重复后,下一次重复读,从62位的padding数据开始读,导致后面的数据有误。
最终,封装多一层,解决了这个问题。
typedef struct {
char ResourceID[ID_SIZE];//ID_SIZE = 49
int result;
}Result ;
typedef struct {
MessageClient MC;
Result result;
}ResultInfo;
//封装Result
read(fd, &mc1, sizeof(MessageClient));//fine
read(fd, &result2, sizeof(Result));//fine
char ResourceID[ID_SIZE];//ID_SIZE = 49
int result;
}Result ;
typedef struct {
MessageClient MC;
Result result;
}ResultInfo;
//封装Result
read(fd, &mc1, sizeof(MessageClient));//fine
read(fd, &result2, sizeof(Result));//fine
ref :