本文主要是介绍文件I/O_lseek函数,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!
每个打开的文件都有一个与其相关联的“当前文件偏移量”。通常,读、写操作都从当前文件偏移量处开始,并使偏移量增加所读写的字节数。按系统默认的情况,当打开一个文件时,除非指定O_APPEND选项,否则该偏移量被设置为0。可以调用lseek显式地为一个打开的文件设置起偏移量。
- #include <unistd.h>
- off_t lseek(int filedes, off_t offset, int whence);
返回值:成功返回新的文件偏移量,出错返回-1
对参数offset的解释与参数whence的值有关。
- 若是SEEK_SET,则将该文件的偏移量设置为距文件开始处offset个字节。
- 若是SEEK_CUR,则将该文件的偏移量设置为当前值加offset,offset可为正或负。
- 若是SEEK_END,则将该文件的偏移量设置为文件长度加offset,offset可为正或负。
可以用下列方式确定打开文件的当前偏移量:
- off_t currpos;
- currpos = lseek(fd, 0, SEEK_CUR);
这种方法也可用来确定所涉及的文件是否可以设置偏移量。如果文件描述符引用的是一个管道、FIFO或网络套接字,则lseek返回-1,并将errno设置为ESPIPE。
通常,文件的当前偏移量应当是一个非负整数,但是,某些设备也可能允许负的偏移量。但对于普通文件,则其偏移量必须是非负值。因为偏移量可能是负值,所有在比较lseek的返回值时应当谨慎,不要测试它是否小于0,而要测试它是否等于-1。
lseek仅将当前的文件偏移量记录在内核中,它并不引起任何I/O操作。
文件偏移量可以大于文件的当前长度,在这种情况下,对该文件的下一次写将加长该文件,并在文件中构成了一个空洞。位于文件中但没有写过的字节都被读为0。文件中的空洞并不要求在磁盘上占用存储区。
来源:http://blog.csdn.net/cxf100900/article/details/5785272
这篇关于文件I/O_lseek函数的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!