1:服务器文件大小复制到缓冲器并发送它:Ç套接字发送和接收int,而不是字符缓冲区
snprintf(t_buf, 255, "%" PRIu32, fsize);
if(send(f_sockd, t_buf, sizeof(t_buf), 0) < 0){
perror("error on sending file size\n");
onexit(f_sockd, m_sockd, 0, 2);
}
2:客户端接收的文件大小,放入FSIZE :
if(recv(f_sockd, t_buf, sizeof(t_buf), 0) < 0){
perror("error on receiving file size");
onexit(f_sockd, 0 ,0 ,1);
}
fsize = atoi(t_buf);
-----------------上面的代码使我的程序完美工作!
的问题发生,如果我写这样的代码,而不是以前的一个:
1:服务器发送FSIZE:
if(send(f_sockd, &fsize, sizeof(fsize), 0) < 0){
perror("error on sending file size\n");
onexit(f_sockd, m_sockd, 0, 2);
}
2,客户端接收FSIZE:
if(recv(f_sockd, &fsize, sizeof(fsize), 0) < 0){
perror("error on receiving file size");
onexit(f_sockd, 0, 0, 1);
}
凡uint32_t fsize;
和char t_buf[256];
。
问题是,使用第一种方法都可以工作,但使用第二种方法,客户端不会收到所有文件,只能收到一小部分文件。这段代码有什么问题?
谢谢!
[处理从recv的部分回报(c)中TCP](可能重复http://stackoverflow.com/questions/1386142/handling-partial-return-from-recv-tcp-in-c) –
看起来不像它,上面的代码只是错误的;-)。 –
客户端和服务器在同一台机器上吗?只是它的一部分意味着什么? – hmjd