我向网络仿真器发送了一个带有一个字段(unsigned int)的struct,它输出了unsigned int,但这是不正确的。
如果我不重新运行网络仿真器,如果我用相同的数字重新发送结构,它将是相同的随机整数。如果我发送这个数字+1,我会得到一个随机整数-1。
如果我重新运行网络仿真器并使用相同的数字重新发送结构,它会显示一个不同的随机整数。
这是结构:
struct pkt_INIT {
unsigned int router_id;
};
下面是发送该结构的代码:
int sock;
struct sockaddr_in server_addr;
struct hostent *host;
char send_data[1024];
host= (struct hostent *) gethostbyname(emulator_host);
if ((sock = socket(AF_INET, SOCK_DGRAM, 0)) == -1)
{
perror("socket");
exit(1);
}
server_addr.sin_family = AF_INET;
server_addr.sin_port = htons(emulator_port);
server_addr.sin_addr = *((struct in_addr *)host->h_addr);
bzero(&(server_addr.sin_zero),8);
struct pkt_INIT init;
init.router_id = router_id;
strcpy(send_data,(char *)&init);
sendto(sock, send_data, strlen(send_data), 0,
(struct sockaddr *)&server_addr, sizeof(struct sockaddr));
我没有网络仿真器的任何代码。
发布于 2012-03-30 09:17:24
不要使用strcpy()
将二进制结构放入二进制数组中。同样,不要使用strlen()
来获取结构的长度。这两个函数都是为字符串设计的,它们将复制/读取字节,直到它们遇到空字节。请改用memcpy()
和sizeof()
:
memcpy(send_data, &init, sizeof(init));
sendto(sock, send_data, sizeof(init), 0, (struct sockaddr *)&server_addr, sizeof(struct sockaddr));
在这种情况下,只需删除数组并将结构直接传递给sendto()
即可:
sendto(sock, (char*)&init, sizeof(init), 0, (struct sockaddr *)&server_addr, sizeof(struct sockaddr));
现在,说到这里,router_id出现了一个问题。
init.router_id = htonl(router_id);
发布于 2012-03-30 07:53:03
您正在使用:strcpy(send_data,(char *)&init);
这真的是你想要做的吗?您正在将结构变量复制到字符数组。假设您只想以这种方式逐个字节地复制,仍然存在问题。init不会有NULL终止。因此,对strlen()
的后续调用是可疑的。
更新:
只需将-1存储在char数组中,并在接收端将其转换为整数。
send_data[0]=255; //To store -1
send_data[1]='\0';
接收器端:
int i;
i = recv_data[0];
“I”将有-1。
https://stackoverflow.com/questions/9935124
复制相似问题