socket文件的特性和管道一样,read时会出现阻塞;
端口查询命令: netstat -apn | grep + 端口号;
注意:当先杀掉server时,然后再重新启动server和客户端,由于此时端口还没有被释放,会出现客户端无法和server通信;
早期UNIX系统的一个特性是:如果在进程执行一个低速系统调用而阻塞期间捕捉到一个信号,则该系统调用就被中断不再继续执行。该系统调用返回出错,其errno设置为EINTR。这样处理的理由是:因为一个信号发生了,进程捕捉到了它,这意味着已经发生了某种事情,所以是个好机会应当唤醒阻塞的系统调用。
具体参考慢系统调用与中断
注意:socket中的accept函数如果返回-1时要进一步判断是否是被信号中断的,如果是被信号打断,则需要可以goto 重新调用accept,如果返回值时ECONNABORTED时也可以goto 到accept重新调用;
read函数返回值总结:1.>0实际读到的字节数,如果buf = 1024 1. ==1024 2. < buf < buf的实际值;
2. = 0数据读完,或者读到(文件,管道,socket末尾–对端关闭,如果对端不写,则会阻塞)
3. -1 异常
1. errno == EINTR 被信号中断重启/quit
2. errno == EAGAIN(EWOULDBLOCK)非阻塞方式读,并且没有数据;
3. errno == 其他值,出现错误,perror exit.