2013-04-12 87 views
1

我正在阅读一本关于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)上,我想知道网络操作是否以奇怪的方式处理。我不应该接受任何事情,因为没有任何联系。

+2

当你从系统调用中得到-1时,你应该检查errno,它告诉你问题是什么。没有这一点,调试只是一个猜测游戏,或者是一个耗时的互联网论坛练习。你当然不应该打印任意的,独立于errno的消息并退出。 – EJP

+0

@EJP这是有道理的。这本书可能并没有包含它,因为它只是一个介绍程序。尽管将来会这样做。 –

回答

4

您需要在bind()accept()之间调用listen()

+1

和循环开始之前:) –