正文
read函数
功能描述:
从文件读取数据。
函数原型
ssize_t read(int fd, void *buf, size_t count);
参数
fd:将要读取数据的文件描述词。
buf:指缓冲区,即读取的数据会被放到这个缓冲区中去。
count:表示调用一次read操作,应该读多少数量的字符。
返回值
(1)返回所读取的字节数;
(2)0(读到EOF);
(3)-1(出错);
以下几种情况会导致读取到的字节数小于 count :
A. 读取普通文件时,读到文件末尾还不够 count 字节。例如:如果文件只有 30 字节,而我们想读取 100
字节,那么实际读到的只有 30 字节,read 函数返回 30 。此时再使用 read 函数作用于这个文件会导致 read 返回 0 。
B. 从终端设备(terminal device)读取时,一般情况下每次只能读取一行。
C. 从网络读取时,网络缓存可能导致读取的字节数小于 count字节。
D. 读取 pipe 或者 FIFO 时,pipe 或 FIFO 里的字节数可能小于 count 。
E. 从面向记录(record-oriented)的设备读取时,某些面向记录的设备(如磁带)每次最多只能返回一个记录。
F. 在读取了部分数据时被信号中断。
测试代码
int main(int argc,char * argv)
{
int fd = -1;/*file descriptor(文件描述符)*/
int ret = -1;
/*1.open file*/
fd = open(MY_FILE,O_RDONLY);
if(fd<0)
{
printf("open err.\r\n");
goto open_err;
}
printf("fd = %d\r\n",fd);
/*2.read file*/
char buf[30] = {0};
ret = read(fd,buf,30);
if(ret<0)
{
printf("read error\r\n");
goto read_err;
}
printf("ret = %d\r\n",ret);
printf("buf = %s\r\n",buf);
/*3.close file*/
close(fd);
return 0;
read_err: close(fd);
open_err: return -1;
}