前言:上篇文章在读取文件数据时需要close之后再重新open刷新指针光标,实际上在文件编程中有专门控制指针光标的函数,就是lseek函数。(read函数从指针光标所在位置向后读取)
参数说明
终端下输入man 2 lseek 查看头文件与相关参数
//头文件
#include <sys/types.h>
#include <unistd.h>
//相关参数
off_t lseek(int fd, off_t offset, int whence);
fd:需要写入文件的文件描述符
offset:指针光标的偏移量,为正数时向后偏移,为负数时向前偏移
whence:从何处开始操作,有如下三种宏可选择:
SEEK_SET: 指针光标从文件开头按照传入的offset进行偏移
SEEK_CUR:指针光标从当前位置按照传入的offset进行偏移
SEEK_END:指针光标从文件末尾按照传入的offset进行偏移
返回值
成功返回偏移量,失败返回-1
代码示例
修改上篇文章代码重新打开file2部分,改为用lseek修改指针光标位置
#include <stdio.h>
//以下是man手册查询的头文件
#include <sys/types.h>
#include <sys/stat.h>
#include <fcntl.h>
#include <unistd.h>
//strlen头文件
#include <string.h>
//malloc头文件
#include <stdlib.h>
int main()
{
int fd;//定义与open函数返回值相同的int型,便于接受返回值
char *buf = "writeabcdefghijklmn";
fd = open("./file1",O_RDONLY);//以只读的方式打开本目录下的file1文件
if(fd == -1) //如果没打开 返回值为-1(肯定打不开,因为没创建)
{
printf("open file1 failed\n");//终端输出打开file1失败
fd = open("./file2",O_CREAT|O_RDWR,0600);//如果不存在则创建以可读可写模式 权限为0600
if(fd > 0)
{
printf("open file2 successful\n");//终端输出打开file2成功
printf("fd = %d\n",fd);//查看返回值
}
}
int n_write = write(fd,buf,strlen(buf));//用strlen计算buf大小
char *readbuf;
//开辟空间
readbuf = (char *)malloc(sizeof(char)*n_write + 1);
//不更改指针光标直接读取数据
int n_read = read(fd,readbuf,100);
printf("read:%d,countext:%s\n",n_read,readbuf);
//指针光标设置在头部,偏移为0
lseek(fd,0,SEEK_SET);
char *readbuf2;
readbuf2 = (char *)malloc(sizeof(char)*n_write + 1);
int n_read2 = read(fd,readbuf2,100);
printf("read2:%d,countext:%s\n",n_read2,readbuf2);
//指针光标设置在头部,偏移为3
lseek(fd,3,SEEK_SET);
char *readbuf3;
readbuf3 = (char *)malloc(sizeof(char)*n_write + 1);
int n_read3 = read(fd,readbuf3,100);
printf("read3:%d,countext:%s\n",n_read3,readbuf3);
close(fd);//资源清理
return 0;
}
编译运行
可以看到,未偏移指针光标之前读取的字节大小为0