gpt4 book ai didi

c++ - recv() 进入无限循环

转载 作者:行者123 更新时间:2023-11-30 05:37:09 25 4
gpt4 key购买 nike

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

当我发送一些字符串时,它可以正常工作,但对于某些字符串,recv() 会进入无限循环

客户端.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 ;
}

服务器.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 ;
}

发送或接收时是否有任何问题,有点卡在这一点上了一段时间。

最佳答案

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 返回的负值。

关于c++ - recv() 进入无限循环,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/33351496/

25 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com