两天后我和C一起玩,我一直遇到新问题。现在我想将我的数据记录到char buf中,但我遇到了一些问题:我的代码如下:
int main(int argc, char *argv[])
{
int sockfd, portno, n;
struct sockaddr_in serv_addr;
struct hostent *server;
unsigned char buf[1024];
struct profile_t
{
unsigned char length;
unsigned char type;
unsigned char *data;
};
typedef struct profile_datagram_t
{
unsigned char src[4];
unsigned char dst[4];
unsigned char ver;
unsigned char n;
struct profile_t profiles[MAXPROFILES];
} header;
header outObj;
outObj.src[0] =1;
outObj.dst[0] = 2;
outObj.ver = 1;
outObj.n = 2;
outObj.profiles[0].length = 10;
outObj.profiles[0].type = 1;
outObj.profiles[1].length = 10;
outObj.profiles[1].type = 2;
memcpy(buf,outObj.src,4);
memcpy(buf+4,outObj.dst,4);
memcpy(buf+8,outObj.ver,1);
memcpy(buf+9,outObj.n,2);
memcpy(buf+10,outObj.profiles[0].length,1);
memcpy(buf+11,outObj.profiles[0].type,1);
memcpy(buf=12,outObj.profiles[0].data,10);
我收到以下错误:
警告:传递
分配到类型memcpy
的参数2使得指针来自整数而没有强制转换 错误:从类型unsigned char[1024]
int
时出现不兼容的类型
错误适用于memcpy()
。任何人都可以向我解释memcpy()
以及我出错的地方。
答案 0 :(得分:6)
您需要传递结构的各个字段的地址。按名称传递数组时,这自动是数组开头的地址。但非数组字段需要地址运算符&
:
memcpy(buf+10,&outObj.profiles[0].length,1);
顺便说一句,如果您更改length
的类型:
memcpy(buf+10,&outObj.profiles[0].length,sizeof(outObj.profiles[0].length));
答案 1 :(得分:1)
我将触及两个主要问题:
您需要使用ver
或n
等结构中非指针项的地址:
/* note the & before outObj.ver */
memcpy(buf+8, &outObj.ver, 1);
您不小心在最后一行为buf
分配了一个值:
memcpy(buf=12,... /* should be buf+12 */
答案 2 :(得分:0)
就像提示一样,如果您确定关于buf
的内存布局和结尾,以及结构(包括其填充和对齐),您可以简单地进行一次转换像:
header * outObj = (header *)buf;
自动访问成员。与header->ver
,header->src
等