非阻塞connect的代码示例


int conn_nonb(int sockfd, const struct sockaddr_in *saptr, socklen_t salen, int nsec)

{

    int flags, n, error, code;

    socklen_t len;

    fd_set wset;

    struct timeval tval;

 

    flags = fcntl(sockfd, F_GETFL, 0);

    fcntl(sockfd, F_SETFL, flags | O_NONBLOCK);

 

    error = 0;

    if ((n == connect(sockfd, saptr, salen)) == 0) {

        goto done;

    } else if (n < 0 && errno != EINPROGRESS){

        return (-1);

    }

 

    /* Do whatever we want while the connect is taking place */

 

    FD_ZERO(&wset);

    FD_SET(sockfd, &wset);

    tval.tv_sec = nsec;

    tval.tv_usec = 0;

 

    if ((n = select(sockfd+1, NULL, &wset, 

                    NULL, nsec ? &tval : NULL)) == 0) {

        close(sockfd);  /* timeout */

        errno = ETIMEDOUT;

        return (-1);

    }

 

    if (FD_ISSET(sockfd, &wset)) {

        len = sizeof(error);

        code = getsockopt(sockfd, SOL_SOCKET, SO_ERROR, &error, &len);

        /* 如果发生错误,Solaris实现的getsockopt返回-1,

         * 把pending error设置给errno. Berkeley实现的

         * getsockopt返回0, pending error返回给error. 

         * 我们需要处理这两种情况 */

        if (code < 0 || error) {

            close(sockfd);

            if (error) 

                errno = error;

            return (-1);

        }

    } else {

        fprintf(stderr, "select error: sockfd not set");

        exit(0);

    }

 

done:

    fcntl(sockfd, F_SETFL, flags);  /* restore file status flags */

    return (0);

}
 

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值