lseek函数出现空洞的返回值是什么啊?
发布网友
发布时间:2022-06-09 22:33
我来回答
共3个回答
热心网友
时间:2024-12-12 08:40
函数名:
lseek
功
能:
移动文件读/写指针
用
法:
long
lseek(int
handle,
long
offset,
int
fromwhere);
所有打开的文件都有一个当前文件偏移量(current
file
offset),以下简称为
cfo。cfo
通常是一个非负整数,用于表明文件开始处到文件当前位置的字节数。读写操作通常开始于
cfo,并且使
cfo
增大,增量为读写的字节数。文件被打开时,cfo
会被初始化为
0,除非使用了
O_APPEND
。
使用
lseek
函数可以改变文件的
cfo
。
lseek
的以下用法返回当前的偏移量:
off_t
currpos;
currpos
=
lseek(fd,
0,
SEEK_CUR);
这个技巧也可用于判断我们是否可以改变某个文件的偏移量。如果参数
fd(文件描述符)指定的是
pipe(管道)、FIFO
或者
socket,lseek
返回
-1
并且置
errno
为
ESPIPE。
对于普通文件(regular
file),cfo
是一个非负整数。但对于特殊设备,cfo
有可能是负数。因此,我们不能简单地测试
lseek
的返回值是否小于
0
来判断
lseek
成功与否,而应该测试
lseek
的返回值是否等于
-1
来判断
lseek
成功与否。
lseek
仅将
cfo
保存于内核中,不会导致任何
I/O
操作。这个
cfo
将被用于之后的读写操作。
如果
offset
比文件的当前长度更大,下一个写操作就会把文件“撑大(extend)”。这就是所谓的在文件里创造“空洞(hole)”。没有被实际写入文件的所有字节由重复的
0
表示。空洞是否占用硬盘空间是由文件系统(file
system)决定的。
编辑本段
程序例
#include
#include
#include
#include
#include
#include
int
main(void)
{
int
handle;
char
msg[]
=
"This
is
a
test";
char
ch;
/*
create
a
file
*/
handle
=
open("TEST.$$$",
O_CREAT
|
O_RDWR,
S_IREAD
|
S_IWRITE);
/*
write
some
data
to
the
file
*/
write(handle,
msg,
strlen(msg));
/*
seek
to
the
begining
of
the
file
*/
lseek(handle,
0L,
SEEK_SET);
/*
reads
chars
from
the
file
until
we
hit
EOF
*/
do
{
read(handle,
&ch,
1);
printf("%c",
ch);
}
while
(!eof(handle));
close(handle);
return
0;
}
追问:
如果
offset
比文件的当前长度更大,下一个写操作就会把文件“撑大(extend)”。这就是所谓的在文件里创造“空洞(hole)”。没有被实际写入文件的所有字节由重复的
0
表示。空洞是否占用硬盘空间是由文件系统(file
system)决定的。
还是没有回答返回值啊
追答:
返回值为0
空洞都被0填充
热心网友
时间:2024-12-12 08:41
函数名:
lseek
功
能:
移动文件读/写指针
用
法:
long
lseek(int
handle,
long
offset,
int
fromwhere);
所有打开的文件都有一个当前文件偏移量(current
file
offset),以下简称为
cfo。cfo
通常是一个非负整数,用于表明文件开始处到文件当前位置的字节数。读写操作通常开始于
cfo,并且使
cfo
增大,增量为读写的字节数。文件被打开时,cfo
会被初始化为
0,除非使用了
O_APPEND
。
使用
lseek
函数可以改变文件的
cfo
。
lseek
的以下用法返回当前的偏移量:
off_t
currpos;
currpos
=
lseek(fd,
0,
SEEK_CUR);
这个技巧也可用于判断我们是否可以改变某个文件的偏移量。如果参数
fd(文件描述符)指定的是
pipe(管道)、FIFO
或者
socket,lseek
返回
-1
并且置
errno
为
ESPIPE。
对于普通文件(regular
file),cfo
是一个非负整数。但对于特殊设备,cfo
有可能是负数。因此,我们不能简单地测试
lseek
的返回值是否小于
0
来判断
lseek
成功与否,而应该测试
lseek
的返回值是否等于
-1
来判断
lseek
成功与否。
lseek
仅将
cfo
保存于内核中,不会导致任何
I/O
操作。这个
cfo
将被用于之后的读写操作。
如果
offset
比文件的当前长度更大,下一个写操作就会把文件“撑大(extend)”。这就是所谓的在文件里创造“空洞(hole)”。没有被实际写入文件的所有字节由重复的
0
表示。空洞是否占用硬盘空间是由文件系统(file
system)决定的。
编辑本段
程序例
#include
#include
#include
#include
#include
#include
int
main(void)
{
int
handle;
char
msg[]
=
"This
is
a
test";
char
ch;
/*
create
a
file
*/
handle
=
open("TEST.$$$",
O_CREAT
|
O_RDWR,
S_IREAD
|
S_IWRITE);
/*
write
some
data
to
the
file
*/
write(handle,
msg,
strlen(msg));
/*
seek
to
the
begining
of
the
file
*/
lseek(handle,
0L,
SEEK_SET);
/*
reads
chars
from
the
file
until
we
hit
EOF
*/
do
{
read(handle,
&ch,
1);
printf("%c",
ch);
}
while
(!eof(handle));
close(handle);
return
0;
}
热心网友
时间:2024-12-12 08:41
设置文件偏移量为绝对值成功或失败,失败则为-1