参考博客:
1.https://blog.csdn.net/u012349696/article/details/50083881
2.https://blog.csdn.net/weixiuc/article/details/2937226
一、read()
1.头文件:unistd.h
2.原型:ssize_t read(int fd, void *buf, size_t nbytes);
从fd指定的已打开文件中读取nbytes字节到buf中,以下几种情况会导致读取到的字节数小于nbytes:
A.读取普通文件时,读到文件末尾还是不够nbytes字节,那么返回实际读取的字节数
B.从终端设备读取时,一般情况下每次只能读取一行
C. 从网络读取时,网络缓存可能导致读取的字节数小于 nbytes 字节。
D. 读取 pipe 或者 FIFO 时,pipe 或 FIFO 里的字节数可能小于 nbytes 。
E. 从面向记录(record-oriented)的设备读取时,某些面向记录的设备(如磁带)每次最多只能返回一个记录。
F. 在读取了部分数据时被信号中断。
3.如果读到了文件末尾,就返回0
二、write()
1.头文件:unistd.h
2.原型:ssize_t write(int fd,const void *buf,size_t nbytes);
从buf中往fd中写入nbytes字节的数据
3.返回值:写入的字节数(成功)/-1(出错,一般都是因为磁盘满了或者超过了文件大小操作)
4.除非打开文件时使用了O_APPEND,不然写操作都是始于cfo的
三、lseek()
1.当前文件偏移量(current file offset):这里简称为cfo,它通常是个非负整数,用于表明文件当前位置到文件开始处的字节数。读写操作通常开始于CFO,并且使CFO增大,增量为读写的字节数。文件被打开时,CFO会被初始化为0.
2.lseek函数就是用来改变cfo的
3.头文件:unistd.h+sys/types.h
4.原型:off_t lseek(int fd,off_t offset,int whence)
5.参数解析:
- fd表示要操作的文件描述符
- offset是相对于whence(基准)的偏移量
- whence可以是SEEK_SET(文件指针开始,值为0),SEEK_CUR(文件指针当前位置,值为1),SEEK_END(文件指针尾,值为2)
6.返回值:新的CFO(成功)/-1(失败)
7.新的CFO怎么算?根据whence取值不同来算
1)若whence为0,则新CFO=offset
2)若whence为1,则新CFO=旧CFO+offset,这个新CFO可以为正可以为负
3)若whence为2,则新CFO=文件长度+offset,这个新CFO可以为正可以为负