使用INADDR_LOOPBACK的环回示例不起作用

时间:2013-05-28 08:53:08

标签: c sockets tcp loopback

我正在尝试在C中设置一个环回套接字,但没有任何作用。我正在尝试创建一个函数,打开一个带有环回地址的套接字,将数据发送到套接字,并从另一个函数读取数据,但没有任何作用。我相信我不知道如何使用与连接相关的功能。这是我到目前为止所取得的成就:

#include <sys/wait.h>       
#include <sys/types.h>       
#include <sys/socket.h>     
#include <netinet/in.h>       
#include <netdb.h>           
#include <unistd.h>             
#include <stdlib.h>         
#include <ctype.h>          
#include <signal.h>         
#include <iostream>
#include <cerrno>
#include <pthread.h>

int internal_s;

void function1(){
    if ((internal_s = socket(AF_INET, SOCK_STREAM, 0)) < 0)
        perror_exit("socket");

    /* Find server address */
    struct sockaddr_in loopback;
    struct sockaddr *serverptr = (struct sockaddr*)&loopback; 

    /*Convert port number to integer*/        
    loopback.sin_family = AF_INET;       /* Internet domain */
    loopback.sin_addr.s_addr=htonl(INADDR_LOOPBACK);
    loopback.sin_port=htons(10000);

    /* Initiate connection */
    if (bind(internal_s,serverptr, sizeof(loopback))<0)
        perro("bind");

    int test=1;
    err=write(internal_s,&test,sizeof(int));
    if(err<0)
        perror(write);
}

void Open_Internal_sock(int socket_s){
    struct sockaddr_in loopback;
    struct sockaddr *serverptr = (struct sockaddr*)&loopback; 

    /*Convert port number to integer*/        
    loopback.sin_family = AF_INET;       /* Internet domain */
    loopback.sin_addr.s_addr=htonl(INADDR_LOOPBACK);
    loopback.sin_port=htons(10000);

    /* Initiate connection */
    if (bind(socket_s,serverptr, sizeof(loopback))<0)
        perror("bind");//Invalid argument
    int test;
    if(read(socket_s,&test,sizeof(int))<0)
        perror("read");//herer it prints:Transport endpoint is not connected
}

int main(){
    function1(i);
    Open_Internal_sock(internal_s);
}

1 个答案:

答案 0 :(得分:4)

简而言之,客户端(发件人,“作家”)需要调用connect(),服务器(监听器,接收者,“读者”)需要调用listen()accept()

服务器和客户端也需要单独的执行线程,因为某些套接字操作会阻塞并导致单个执行线程永远停止。最简单的可能是将server.c和client.c作为单独的程序。

此外,尝试在启用警告的情况下编译代码,例如gcc -Wall。现在有很多错误,编译器可以为您指出。要获得更清晰的消息,请尝试使用clang代替gcc作为编译器。

我建议查看http://kohala.com/start/unpv12e/unpv12e.tar.gz。使用tar xzvf unpv12e.tar.gz解压缩并查看unpv12e / tcpcliserv / tcpcli01.c和unpv12e / tcpcliserv / tcpserv01.c。如果您想要复制和粘贴,请注意,例如Listen()中的大写字母需要更改为小写,以使代码在没有unpv标头的情况下工作。此更改还会删除所有错误检查,因此请进行自己的错误处理。