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;

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

最后一次读的有误。读出的不是传的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

 

 ref :

http://blog.csdn.net/zzffly9/article/details/1844421

相关文章:

  • 2021-09-18
  • 2022-12-23
  • 2022-01-29
  • 2021-05-25
  • 2022-02-04
  • 2021-09-22
  • 2021-05-31
  • 2022-12-23
猜你喜欢
  • 2022-02-02
  • 2022-12-23
  • 2021-04-08
  • 2022-12-23
  • 2021-07-20
相关资源
相似解决方案