socket 服务器关闭以后之地址复用

来源:互联网 发布:msp驱动mac 编辑:程序博客网 时间:2024/06/08 17:23

1.问题的出现

这个问题是当我在关掉服务器的时候,没有关掉客户端的时候出现了,于是我去查找原因后来发现说可以用地址复用解决,在我看来地址复用就是修改tcp服务器的状态而设定,这只是我的猜测。

2.解决方案

setsockopt这个函数,它有四个参数,详细的请查看api说明

3.代码实现

#include<unistd.h>#include<sys/stat.h>#include<sys/wait.h>#include<sys/types.h>#include<stdlib.h>#include<stdio.h>#include<fcntl.h>#include<errno.h>#include<string.h>#include<signal.h>#include<arpa/inet.h>#include<sys/socket.h>#include<netinet/in.h>int main(){    int sockfd = 0;    sockfd = socket(PF_INET,SOCK_STREAM,0);    if(sockfd == -1)    {        perror("socket fun is error\n");        exit(0);    }    struct sockaddr_in srvaddr;    srvaddr.sin_family = AF_INET;    srvaddr.sin_port = htons(8001);    srvaddr.sin_addr.s_addr = inet_addr("127.0.0.1");       int optval = 1;    if(setsockopt(sockfd,SOL_SOCKET,SO_REUSEADDR,&optval,sizeof(optval)))    {        perror("setsockopt is error\n");        exit(0);    }        if(bind(sockfd,(struct sockaddr*)&srvaddr,sizeof(srvaddr))<0)    {        perror("bind func error\n");        exit(0);    }    //监听    if(listen(sockfd,SOMAXCONN)<0)    {        perror("listen fun is error\n");        exit(0);    }    //客户端结构体    struct sockaddr_in perraddr;    socklen_t peerlen = sizeof(perraddr);    unsigned int conn = 0;    //接受三次握手链接    conn = accept(sockfd,(struct sockaddr*)&perraddr,(socklen_t*)&peerlen);    if(conn==-1)    {        perror("accept fun is error\n");        exit(0);    }    char revbuf[1024] = {0};    for(;;)    {        int ret = read(conn,revbuf,sizeof(revbuf));        if(ret == 0)        {            printf("对方已经关闭\n");            exit(0);        }        else if(ret<0)        {            perror("读取数据失败\n");            exit(0);        }            fputs(revbuf,stdout);        write(conn,revbuf,ret);    }    close(conn);    close(sockfd);    return 0;}


最后在给大家一个运算结果
原创粉丝点击