linuxopen文件偏移

linuxopen文件偏移,第1张

通过函数lseek可以改变文件当前的读写位置

函数原型

#include <sys/types.h>

#include <unistd.h>

off_t lseek(int fd, off_t offset, int whence)

参数属性:

offset:表示从文件的whence位置开始偏移的位置大小。

whence:表示文件偏移的位置

有三个选项:

SEEK_SET:表示从文件开始位置偏

SEEK_CUR:表示从文件当前的读写位置偏

SEEK_END:表示从文件的结束位置偏移seek.。

int main

//打开文件

int fd = open("b.bat",O_CREAT|O_RDWR)

if(fd == -1)

perror("错误:"),exit(-1)

//准备数据

char *str = "abcdefghigklmn"

//写入数据

write(fd,str,strlen(str))

//准备空间

char buf[32] = {0}

//将文件的读写位置移动到文件的开始

lseek(fd,0,SEEK_SET)

//读取5个字节的数据

read(fd,buf,5)

//输出

puts(buf)

//关闭文件

close(fd)

文件偏移量的移动时机:

1、lseek主动移动偏移量

2、read会移动偏移量

3、write会移动偏移量

进程 --》运行--》进程在内存中存在一个进程表项(文件表) //文件表在内核管理的内存空间中

文件最开始运行时,有三个“文件描述符”已经打开:0,1,2

当使用open函数打开一个文件的时候,系统就会创建一个文件表

文件表的内容:

1、文件状态标志:O_RDONLY \O_WRONLY...

2、文件偏移量(刚打开的文件偏移量为0)

3、V节点指针:指向“v节点表” //V节点表(磁盘的文件系统上):V节点信息、I节点信息、文件大小

你自己已经解释了呀。

为何要用char*类型的指针和unsigned long*类型的指针做运算呢?

No, 不是char*类型的指针和unsigned long*类型的指针做运算,而是char*类型的指针和unsigned long类型做运算,得到的结果还是一个指针,这才符合代码的目的(当前地址-偏移量 = 结构体指针)。如果后面是一个unsigned long*类型的指针,得到的结果就是一个偏移量,不符合代码的目的了。


欢迎分享,转载请注明来源:内存溢出

原文地址: http://outofmemory.cn/yw/7224349.html

(0)
打赏 微信扫一扫 微信扫一扫 支付宝扫一扫 支付宝扫一扫
上一篇 2023-04-03
下一篇 2023-04-03

发表评论

登录后才能评论

评论列表(0条)

保存