您的位置:首页 > 运维架构 > Linux

errno!=EINTR

2013-10-21 20:39 337 查看
errno!=EINTR注意read()如果读到数据为0,那么就表示文件结束了,如果在读的过程中遇到了中断那么会返回-1,同时置errno为EINTR。 因此判断read的条件: 如果read返回<=0 如果==0 表示文件结束, 处理 如果<0 && errno==EINTR 表示中断,处理 否则,出错 但是write()如果写入的数据为0,那么就表示出错,也就是无法写入了,而如果在写的过程中遇到了中断,那么write()会返回-1,同时置errno为EINTR。 因此判断write是否成功时,条件是write返回的结果是否<=0
if<=0 { if<0 if="" errno="=EINTR" else="" if="=0" break="" ssize_t="" 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; else return ( -1 ); } nleft-=nread; ptr+=nread; } return ( n-nleft ); } ssize_t writen ( int fd, const void *ptr, 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); } 写函数write ssize_t write(int fd,const void *buf,size_t nbytes) write函数将buf中的nbytes字节内容写入文件描述符fd。成功时返回写的字节数,失败时返回-1,并设置errno变量。
在网络程序中,当我们向套接字文件描述符写时有俩种可能: 1) write的返回值大于0,表示写了部分或者是全部的数据; 2) 返回的值小于0,此时出现了错误,我们要根据错误类型来处理。 如果错误为EINTR表示在写的时候出现了中断错误。如果为EPIPE表示网络连接出现了问题(对方已经关闭了连接)。 读函数read   ssize_t read(int fd,void *buf,size_t nbyte)   read函数是负责从fd中读取内容。当读成功时,read返回实际所读的字节数。如果返回的值是0,表示已经读到文件的结束了。小于0表示出现了错误。如果错误为EINTR说明读是由中断引起的,如果是ECONNREST表示网络连接出了问题。

 

一下是学习时读的代码:

#include <sys/types.h>

#include <sys/stat.h>

#include <fcntl.h>

#include <stdio.h>

#include <errno.h>

#define BUFFER_SIZE 1024

int main(int argc,char **argv)

{

int from_fd,to_fd;

int bytes_read,bytes_write;

char buffer[BUFFER_SIZE];

char *ptr;

if(argc!=3)

{

fprintf(stderr,"Usage:%s fromfile tofile/n/a",argv[0]);

exit(1);

}

/* 打开源文件 */

if((from_fd=open(argv[1],O_RDONLY))==-1)

{

fprintf(stderr,"Open %s Error:%s/n",argv[1],strerror(errno));

exit(1);

}

/* 创建目的文件 */

if((to_fd=open(argv[2],O_WRONLY|O_CREAT,S_IRUSR|S_IWUSR))==-1)

{

fprintf(stderr,"Open %s Error:%s/n",argv[2],strerror(errno));

exit(1);

}

/* 以下代码是一个经典的拷贝文件的代码 */

while(bytes_read=read(from_fd,buffer,BUFFER_SIZE))

{

/* 一个致命的错误发生了 */

if((bytes_read==-1)&&(errno!=EINTR)) break;

else if(bytes_read>0)

{

ptr=buffer;

while(bytes_write=write(to_fd,ptr,bytes_read))

{

/* 一个致命错误发生了 */

if((bytes_write==-1)&&(errno!=EINTR))break;

/* 写完了所有读的字节 */

else if(bytes_write==bytes_read) break;

/* 只写了一部分,继续写 */

else if(bytes_write>0)

{

ptr+=bytes_write;

bytes_read-=bytes_write;

}

}

/* 写的时候发生的致命错误 */

if(bytes_write==-1)break;

}

}

close(from_fd);

close(to_fd);

exit(0);

}

 
内容来自用户分享和网络整理,不保证内容的准确性,如有侵权内容,可联系管理员处理 点击这里给我发消息
标签:  Linux 系统编程