前言
操作系统:Fedora
头文件 <sys/types.h> , <unistd.h>
lseek函数返回值
off_t oldpos(int fd,off_t dist,int base)
当lseek执行成功时,它会返回最终以文件起始位置为起点的偏移位置。如果出错,则返回-1,同时errno被设置为对应的错误值。
而不是《Linux编程基础》中所说 “当执行成功时,返回值oldpos为移动之前的位置”
实操证明
#include <fcntl.h>
#include <sys/types.h>
#include <unistd.h>
#include <stdio.h>
#include <string.h>
#include <stdlib.h>
int main(){
char ch;
char filename[1024];
int n=2;
int fd=open("hello.txt",O_RDONLY);
off_t oldpos=lseek(fd,1,SEEK_SET);//设此时指针指向a位置
printf("%d\n",oldpos);
oldpos=lseek(fd,1,SEEK_CUR);//此时oldpos为b1
printf("%d\n",oldpos);
printf("\n");
close(fd);
return 0;
}
如果按这本书上所说,那么这里应该是 b1=a
修改第二次调用 lseek 函数的参数
oldpos=lseek(fd,5,SEEK_CUR);//此时oldpos为b2
再次执行程序,应该有 b2=a
所以,如果书上是对的,那么应该有 b2=b1
下面分别为两次执行的结果
可以看到 b1=2,b2=6 ,所以可以得出,书上的说法是错误的
书的原图
这里书中还有的小错误:头文件应该是 <sys/types.h>
总结
1.当lseek执行成功时,它会返回最终以文件起始位置为起点的偏移位置(即指针所指位置-1)。如果出错,则返回-1,同时errno被设置为对应的错误值。
eg:假设一个文件的内容为 abcdefg,那么当指针指向 c 时,返回值为2(离起始点 a 偏移2)
2.尽信书不如无书,因为这本书的错误,我用了大把青春年华调试代码,还是觉得逻辑有问题,结果一查发现书给出错了(疲惫.jpg): (
(下面是我按书调试了半天的代码)