我正在阅读一本关于 c 中套接字的书,并且正在制作一个非常简单的服务器程序。我逐字复制代码。目前还没有尝试连接到该服务器程序,并且已经多次更改端口以确保。
该程序在第一次运行循环时在接受方法上失败。根据我在手册页中阅读的内容,accept 应该阻止调用者直到建立连接,并且如果队列中没有像它正在做的连接,则不会失败。是否有任何理由接受会返回小于 0 的值?我会将代码发布到失败的地方:
#include <stdio.h>
#include <stdlib.h>
#include <string.h>
#include <sys/types.h>
#include <sys/socket.h>
#include <netinet/in.h>
#include <arpa/inet.h>
//Max number of outstanding connection requests
#define MAXPEDNING 5
#define NONE
#define BUFSIZE 1024
int main(int argc, char **argv)
{
in_port_t servPort;
#ifdef CMDLINE
if(argc != 2)
{
puts("Error! Usage is <Server Port>");
return 0;
}
servPort = atoi(argv+1);
#endif //CMDLINE
#ifdef NONE
servPort = 2549;
#endif //NONE
int servSock;
if((servSock = socket(AF_INET, SOCK_STREAM, IPPROTO_TCP)) < 0)
{
puts("socket() failed");
return 0;
}
struct sockaddr_in servAddr;
memset(&servAddr, 0, sizeof(servAddr));
servAddr.sin_family = AF_INET;
servAddr.sin_addr.s_addr = htonl(INADDR_ANY);
servAddr.sin_port = htons(servPort);
printf("Port in network order: %d\nPort in host order:%d\n", servAddr.sin_port, ntohs(servAddr.sin_port));
if((bind(servSock, (struct sockaddr*) &servAddr, sizeof(servAddr)))<0)
{
puts("bind failed");
return 0;
}
while(1)
{
struct sockaddr_in clntAddr;
socklen_t clntAddrLen = sizeof(clntAddr);
int clntSock = accept(servSock, (struct sockaddr*) &clntAddr, &clntAddrLen);
if(clntSock < 0)
{
puts("accept failed");
return 0;
}
它达到接受失败并退出。我的设置唯一奇怪的是我在 Debian VM (VirtualBox) 上,我想知道网络操作是否以一种奇怪的方式处理。我什至不应该试图接受任何东西,因为没有任何联系。