这一章介绍的知识点包括:
1.学习设备无关的I/O的基本知识
2.进行read和write的实验
3.研究监测多个描述符的方法
4.使用正确的错误处理方式
5.理解文件描述符的继承
read()和write()函数
read()从已打开的、与文件描述字filedes相连的文件中读至多nbytes个字节的数据放到buffer所指缓冲区中。它的正常返回值是实际读入的字节数,若在实际读入字节之前便遇到文件尾,其返回值为0。read()是所有读流的函数(如fgets()等)的低级原语。
数据类型ssize_t与size_t类似,UNIX系统也用它表示在一次操作中可以读写的块大小。不过与size_t不同的是,它是一个有符号整型以便能够表示错误情形的返回值。read()返回的实际读入字节数在以下几种情况下可能小于nbytes:
当读普通文件且在还未读够所请求的字节数便遇到了文件尾时。例如,当文件中只剩下30个字节便到达文件尾,而我们却企图读100个字节时,read()将返回30。下一次再调用read(),它将返回0指出文件结束。
当所读的文件对应于终端设备时,通常每次至多只读一行。
当从网络读时,网络的内部缓冲可能导致读入的字节数少于所请求的字节数。
当被信号中断时,若已读入若干字节,则返回已读的字节数;否则返回–1,并置errno为EINTR。