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 :