1
int main(int argc, char *argv[]) 

{

int i, j, count;
int f1;
char buf[16];
f1 = open(argv[1], O_RDWR | O_APPEND);
if(f1 == -1)
    perror("open failed");

if(lseek(f1, 0, SEEK_SET) == -1)
    printf("lseek failed\n");


while(count = read(0, buf, 16)) {
    write(f1, buf, count);
}

close(f1);
return 0;
}

这是我的代码。它打开作为参数给出的文件,并且应该在文件开头从控制台写入所有内容。该文件以附加模式打开,然后使用 lseek 将描述符移动到开头。f1 的值没有变化,不是打印 lseek failed 。

4

1 回答 1

2

因为如果文件以 O_APPEND 模式打开,每次调用 write() 时,偏移量指针都会移动到文件的末尾以处理原子操作。

这用于许多进程将“文本”附加到文件中的目的。(例如日志文件)仅从文件末尾开始。

所以尝试将代码更改为:

仅在 O_RWONLY 标志中打开文件(如果需要寻求 EOF,请使用 lseek())。

如果在 open() 中不使用 O_APPEND 标志,write() 不会在每次调用时自动将偏移量移动到 EOF。

于 2016-10-18T10:49:08.850 回答