过于结构体,存进char *的buff,再写入文件 财富值67

2016-11-01 14:11发布

struct data {     u_short sin_port;     struct  in_addr sin_addr;     unsigned char id; };  struct data Data[141];  char *buf,*buf1, buf1 = (char *)malloc(10000); memset(buf1, 0, 10000);  for (i =0;i< 141;i++)  {         memcpy(buf1, &Data[i].id,20);         printf("buf11: %x
", buf1);         buf1+=20;         memcpy(buf1, &Data[i].sin_addr, 4);         buf1+=4;         memcpy(buf1, &Data[i].sin_port, 2);         buf1+=2;         size1 += 26;  }  buf1 -= size1;     write(fd2, buf1, size1+1); close(fd2); free(buf1); 

我发现这样写入的数据总是不对/?请教哪里有问题啊?一般都是先写入buffer,再写入文件?

友情提示: 此问题已得到解决,问题已经关闭,关闭后问题禁止继续编辑,回答。
该问题目前已经被作者或者管理员关闭, 无法添加新回复
6条回答

这是buf空间的前对应字节空间即存储了d1的值

buf1是字符串类型,应该有结束符‘0’来收尾,否则会有乱码。

不要这么麻烦。你顶一个struct的指针,指向"buf指针强转型后的位置",然后将你要copy的struct赋值过来即可。
char* buf = new char[100];
struct Data d1; // init d1
struct Data d2 = (struct Data)buf;
*d2 = d1;

……

1.标题“过于结构体” , 应该是“对于结构体”
2.“char buf, buf1,” , 最好用西文分号结束。
3.内存拷贝memcpy的具体含义参考下标准手册,按你的意思,应该是这个函数第三个参数问题。

赋值前先初始化 buf = buf1 保存数据起始位置
最后使用buf而不是buf1写入数据 write(fd2, buf, size1+1);
buf1 -= size1 也是多余处理

一周热门 更多>