我正在閱讀一本關於c套接字的書,並且正在製作一個非常簡單的服務器程序。我逐字複製了代碼。沒有試圖連接到這個服務器程序,並已多次更改端口以確保。當套接字中沒有連接時,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)上,我想知道網絡操作是否以奇怪的方式處理。我不應該接受任何事情,因爲沒有任何聯繫。
當你從系統調用中得到-1時,你應該檢查errno,它告訴你問題是什麼。沒有這一點,調試只是一個猜測遊戲,或者是一個耗時的互聯網論壇練習。你當然不應該打印任意的,獨立於errno的消息並退出。 – EJP
@EJP這是有道理的。這本書可能並沒有包含它,因爲它只是一個介紹程序。儘管將來會這樣做。 –