Chinaunix

标题: ---------------------- [打印本页]

作者: sesame0816    时间: 2008-12-07 18:00
标题: ----------------------
本帖最后由 sesame0816 于 2014-09-27 16:30 编辑

----------------------
作者: 雨过白鹭洲    时间: 2008-12-07 19:03
想看看你readn和writen的实现

我简单地看了下程序

客户端writen(sockfd, str, strlen(str) + 1); 发送了strlen(str) + 1个字节,这里应该是13吧

而服务端却期望接收MAXLINE字节,这样readn调用recv将阻塞

客户端Ctrl + C后,由于socket关闭,服务端recv调用返回0,于是readn中的循环退出,你就看到了输出

大概如此,仅做参考
作者: xinglp    时间: 2008-12-07 19:03
writen readn 是系统调用么
作者: sesame0816    时间: 2008-12-07 19:06
#define MAXLINE 1024

readn和writen是unp的作者定义的函数。实现如下:

ssize_t writen(int fd, const void *vptr, size_t n)
{
        size_t       nleft;
        ssize_t      nwritten;
        const char   *ptr;

        ptr = vptr;
        nleft = n;

        while(nleft > 0)
        {
                if ((nwritten = write(fd, ptr, nleft)) <= 0)
                        if (nwritten < 0 && errno == EINTR)
                                nwritten = 0;
                        else
                                return -1;
                nleft -=nwritten;
                ptr +=nwritten;
        }
        return n;
}

ssize_t                                                /* Read "n" bytes from a descriptor. */
readn(int fd, void *vptr, size_t n)
{
        size_t        nleft;
        ssize_t        nread;
        char        *ptr;

        ptr = vptr;
        nleft = n;
        while (nleft > 0) {
                if ( (nread =read(fd, ptr, nleft)) < 0) {
                        if (errno == EINTR)
                                nread = 0;                /* and call read() again */
                        else
                                return(-1);
                } else if (nread == 0)
                        break;                                /* EOF */

                nleft -= nread;
                ptr   += nread;
        }
        return(n - nleft);                /* return >= 0 */
}




欢迎光临 Chinaunix (http://bbs.chinaunix.net/) Powered by Discuz! X3.2