recv()进入无限循环

时间:2015-10-26 17:05:06

标签: c++ string sockets

我试图一次发送一个4字节的文件,如果文件内容的长度不能被4整除,我会添加一些额外的空间而我发送它

当我发送一些字符串时它正在工作但是对于某些字符串recv()进入无限循环

Client.cpp

#include <iostream>
#include <sys/socket.h>
#include <netinet/in.h>
#include <arpa/inet.h>
#include <sys/types.h>


using namespace std;

int main(){

int ssock , csock ; 
struct sockaddr_in server ;

server.sin_family = AF_INET ; 
server.sin_port = htons(8088);
server.sin_addr.s_addr = inet_addr("127.0.0.1");


ssock = socket (AF_INET,SOCK_STREAM,0);
if (ssock == -1 ) {
                cout << " Error " ; return 0 ;
        }

connect(ssock , (sockaddr *)&server ,sizeof(server));
/*void *buff ; 
int len = recv(ssock , buff ,1024,0 );
int  *ptr =  (int *)buff ;
cout << *ptr ;*/
void * buff ;
int len;
while(len = recv(ssock , buff ,4,0 )){
        cout<<(char *)buff<<len<<"\n";


}


  return 0 ;
}

server.cpp

#include <iostream>
#include <sys/socket.h>
#include <sys/types.h>
#include <netinet/in.h>
#include <arpa/inet.h>
#include <fstream>
#include <cstring>
#include <unistd.h>


using namespace std;

int main(){

int ssock , csock ; 
struct sockaddr_in server ;

server.sin_family = AF_INET ; 
server.sin_port = htons(8088);
server.sin_addr.s_addr = inet_addr("127.0.0.1");


ssock = socket (AF_INET,SOCK_STREAM,0);
if (ssock == -1 ) {
                cout << " Error " ; return 0 ;
        }

bind(ssock , (sockaddr *)&server ,sizeof(server));
listen(ssock,5);
socklen_t size  = sizeof (server );
fstream fin("text.txt",ios::in);
string s((istreambuf_iterator<char>(fin)),istreambuf_iterator<char>());
fin.close();
//cout<<s;
int len = s.size();
if(len % 4 != 0 ) {
        s.pop_back();
        int i = len % 4 ;
        i =  4 - i ;
        while(i){s.push_back(' ');i--;}
        s.push_back('\0');
}
cout<<s<<"\n"<<s.size()<<"\n";

while(csock = accept(ssock,(sockaddr *)&server ,&size)){

        cout<<"\n Connection Accpeted \n" ;
        /*int s = 172;
        send(csock , (void *)&s, sizeof(s),0);*/
       int i = 0;

        i = 0 ;
        while(i <= s.size()){
        string temp =s.substr(i,4);
        cout<<temp<<"\n";
        cout<<send(csock,(void *)temp.c_str() ,4,0);
        i+=4;
        }

        close(csock);





}

  return 0 ;
}

发送或接收时是否有任何问题,有时候会陷入困境。

2 个答案:

答案 0 :(得分:1)

void * buff ;
int len;
while(len = recv(ssock , buff ,4,0 )){
    cout<<(char *)buff<<len<<"\n";
}

这里至少有三个错误:

  1. 您将buff的值传递给recv,但您尚未设置任何值。所以你要传递垃圾。

  2. 当您将char *传递给cout时,它必须是C风格的字符串。您无法使用它来打印从连接中收到的任意数据。首先,它如何知道要打印多少字节?

  3. 您不会处理recv返回的否定值。

答案 1 :(得分:0)

检查recv的返回值是否为-ve值。否则,你会错过任何错误。

  

这些调用返回接收的字节数,如果发生错误则返回-1。当对等体执行有序关闭时,返回值将为0。