Chinaunix首页 | 论坛 | 博客
  • 博客访问: 4029202
  • 博文数量: 366
  • 博客积分: 9916
  • 博客等级: 中将
  • 技术积分: 7195
  • 用 户 组: 普通用户
  • 注册时间: 2011-05-29 23:27
个人简介

简单!

文章分类

全部博文(366)

文章存档

2013年(51)

2012年(269)

2011年(46)

分类: C/C++

2012-02-07 15:37:16

      在linux的socket编程中,经常要处理EINTR错误,其值为4,用strerror(errno)调用返回的错误描述为:Interrupted system call. 这里给出一个connect连接中对EINTR处理的网址:

   

    另外转载网络上其他兄弟对EINTR错误的处理:

    1. accetp()是慢系统调用,在信号产生时会中断其调用并将errno变量设置为EINTR,此时应重新调用accept()。所以使用时应这样:(网址:)

        while(1)
        {
            if ((connfd = accept(....)) == -1)
            {
                if (errno == EINTR)
                {
                    continue;
                }
                perror("accept()");
                exit(1);
            }
 
            //do something with the connfd
            ......;
        }
 
        2. 引用网址 ,其中摘引一段socket的读处理,我把排版做了相应改动:
        int my_read(int fd, void *buffer, int length)
        {
             int bytes_left;
             int bytes_read;
             char *ptr = NULL;
  
             bytes_left = length;
             while (bytes_left > 0)
             {
                 bytes_read = read(fd, ptr, bytes_read);
                 if (bytes_read < 0)
                 {
                     if (errno == EINTR)
                     {
                         bytes_read = 0;
                     }
                     else
                     {
                         return(-1);
                     }
                 }
                 else if (0 == bytes_read)
                 {
                    break;
                 }
            
                 bytes_left -= bytes_read;
                 ptr += bytes_read;
             }
        
             return(length-bytes_left);
        }
        这个只能针对阻塞模式的socket,非阻塞模式的socket好要处理EAGAIN错误。

摘自 http://blog.sina.com.cn/s/blog_5acb430f0100aer1.html
阅读(3368) | 评论(0) | 转发(0) |
给主人留下些什么吧!~~