文件IO—3.6 lseek函数
lssek现实地为一个打开文件设置偏移量。通常,
读、写操作都从当前文件偏移量处开始,并使偏移量增加所读或写的字节数。按系统默认,当
打开一个文件时,除非指定O_APPEND选择项,否则该位移量被设置为0,函数原型:
#include <sys/types.h>
#include <unistd.h>
off_t lseek(int fd, off_t offset, int whence) ;
//返回:若成功为新的文件偏移量,若出错为- 1
参数分析:
fd:文件描述符,文件描述符0(STDIN_FILENO)与进程的标准输入相结合,文件描述符1(STDOUT_FILENO)与标准输出相结合,文件描述符2(STDERR_FILENO)与标准出错输出相结合。
offset:偏移量设置
whence:若是SEEK_SET,则将该文件的位移量设置为距文件开始处offset个字节。若是SEEK _CUR,则将该文件的位移量设置为其当前值加offset, offset可为正或负。若是SEEK_END,则将该文件的位移量设置为文件长度加offset, offset可为正或负。
测试其标准输入能否被设置位移量的例子
if(lseek(STDIN_FILENO,0,SEEK_CUR) == -1)
printf("can not seek\n");
else
printf("seek ok\n");
注:通常,文件的当前位移量应当是一个非负整数,但是,某些设备也可能允许负的位移量。但对于普通文件,则其位移量必须是非负值。因为位移量可能是负值,所以在比较 lseek的返回值时应当谨慎,不要测试它是否小于0,而要测试它是否等于-1。
创建一个空洞文件的例子
#include "apue.h"
#include <fcntl.h>
char buf1[] = "abcdefghij";
char buf2[] = "ABCDEFGHIJ";
/* #define FILE_MODE (S_IRUSR | S_IWUSR | S_IRGRP | S_IROTH) */
int main(void)
{
int fd;
if((fd = creat("file.hole", FILE_MODE)) < 0)
err_sys("create error");
if(write(fd, buf1, 10) != 10)
err_sys("buf1 write error");
/* offset now = 10 */
if(lseek(fd, 16384, SEEK_SET) == -1)
err_sys("lseek error");
/* offset now = 16384 */
if(write(fd, buf2, 10) != 10)
err_sys("buf2 write error");
/* offset now = 16394 */
exit(0);
}
在学习中进步,如有错误,请多多批评指正