C++ 套接字接受块 cout

c++ socket accept blocks cout

本文关键字:cout 套接字 C++      更新时间:2023-10-16

总的来说,我对C++/C很陌生,所以如果这个问题看起来有点愚蠢,请原谅我,但我真的被困在这里了。

我正在尝试做的是一个简单的 tcp 服务器,让用户有机会接受/拒绝传入连接。我有一个名为waitingForConnection((的函数,其中包含主循环。在套接字成功绑定并标记为被动后,在 main 函数中调用它。

我所期望的是,在客户端连接到服务器后,函数handleConnection((被调用,导致主循环等到函数执行,然后才连续。 但实际上似乎发生的事情是,在handleConnection(( 完全执行之前,主循环继续到下一个accept((调用,该调用阻塞了线程。仅当客户端第二次连接并且线程再次唤醒时,测试输出"done"才会变得可见。

对我来说,代码似乎是完全无序执行的,我认为这是不可能的,因为整个代码应该在单个线程中执行。

首次连接尝试后的控制台输出("n"是用户输入(:

"Accept connection ? (y/n)"n

第二次连接尝试后的控制台输出:

"Accept connection ? (y/n)"n 
"doneAccept connection ? (y/n)"

请注意,我不是在使用select((或类似的东西寻找任何解决方法,我只是想了解为什么代码会这样做,以及如何通过更改结构来修复它。

int soc = socket(AF_INET, SOCK_STREAM, 0);
void handleConnection(int connectionSoc, sockaddr_in client){
string choice;
cout<<"Accept connection ? (y/n)";
cin>>choice;
if(choice=="y"||choice == "Y"){
//do something here
}else{
close(connectionSoc);
}
cout<<"done";
}

void waitingForConnection(){
while(running){
sockaddr_in clientAddress;
socklen_t length;
length = sizeof(clientAddress);
int soc1 = accept(soc,(struct sockaddr*)&clientAddress, &length);
if(soc1<0){
statusOutput("Connection failed");
}else{
handleConnection(soc1, clientAddress);
}
}
}

问题是输出到std::cout是缓冲的,在刷新之前你根本看不到它。当std::cin自动刷新std::cout时,您会在下一个输入上获得输出。将输出更改为:

std::cout << "done" << std::endl;

你会得到预期的行为。