默认 socket 是阻塞的 解阻塞与非阻塞recv返回值没有区分,都是 <0 出错; =0 连接关闭; >0 接收到数据大小;
特别:
- 只是阻塞模式下recv会阻塞着接收数据,非阻塞模式下如果没有数据会返回,不会阻塞着读,因此需要循环读取。
返回说明:
- 成功执行时,返回接收到的字节数;
- 另一端已关闭则返回0;
- 失败返回-1;
- 返回值<0时并且(errno == EINTR || errno == EWOULDBLOCK || errno == EAGAIN)的情况下认为连接是正常的,继续接收。
printf("======== START READ ========");
recv(socketHandle, buff, 4*1024, 0);
printf("======== END READ ========");
//4*1024 表示一次性读取的最大字节数
//打印信息,开始收到接收完需要343ms,很可能在的时候,对端正在写;
//[03Jan20 21:54:35:998] 222258,0548,level:06,-======== START READ ========
//[03Jan20 21:54:36:341] 222258,0549,level:06,-======== END READ ========