error!=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表示网络连接出了问题。
void g_pZmqCtx = zmq_ctx_new(); void pMsgSocket = zmq_socket(g_pZmqCtx, ZMQ_SUB); if (!pMsgSocket) { std::cout << “Failed to create message socket” << std::endl; return; } if (0 != zmq_connect(pMsgSocket, TEST_MSG_ADDR)) { std::cout << "Failed to connect the message socket! code = " << zmq_errno() << " reason = " << zmq_strerror(zmq_errno()) <<std::endl; } zmq_setsockopt(pMsgSocket, ZMQ_SUBSCRIBE, “”, 0); zmq_msg_t filter, frameHeader,imgData; zmq_msg_init(&filter); zmq_msg_init(&frameHeader); zmq_msg_init(&imgData); int nRecvLen = 0; while (true) { QApplication::processEvents(); nRecvLen = zmq_msg_recv(&filter, pMsgSocket, 0); if (nRecvLen < 0) { int err = zmq_errno(); printf(“Error: %s\n”, zmq_strerror(err)); std::cout << “Failed to receive filter” << std::endl; } else { nRecvLen = zmq_msg_recv(&frameHeader, pMsgSocket, 0); ((char)zmq_msg_data(&frameHeader))[nRecvLen] = ‘\0’; QJsonObject objData; QJsonParseError error; QJsonDocument doc = QJsonDocument::fromJson((char)zmq_msg_data(&frameHeader), &error); if (error.error != QJsonParseError::NoError) { qDebug() << “QJsonParseError” << error.errorString(); } objData = doc.object(); int nIndex = objData[“index”].toInt(); int nWidth = objData[“width”].toInt(); int nHeight = objData[“height”].toInt(); if (0 == std::string(static_cast<char*>(zmq_msg_data(&filter))).find(“RgbImg”)) { int nChannels = objData[“channels”].toInt(); nRecvLen = zmq_msg_recv(&imgData, pMsgSocket, 0); if (nRecvLen < 0) { std::cout << “Failed to receive message” << std::endl; } else { std::cout << "receive rgb data index : " << nIndex << std::endl; … … } } } } 优化这段代码
最新发布
08-06
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值