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