首页 > 解决方案 > 将字符串存储在二进制文件中而不被覆盖

问题描述

所以首先,这是我的代码的相关部分,然后我将继续解释。

scanf("%d", &option);
    fflush (stdin);

    //Insert
    if(option==1){

        printf("enter name\n");
        fgets(name,MAX_SIZE,stdin);
        printf("name: %s",name);

        char str[]="alpha one";
        fd=open(argv[1],O_RDWR|O_CREAT|O_TRUNC,S_IRWXU);
        write(fd,str,strlen(str) + 1);

        pcounter = updateCounter(pcounter, str);

        lseek(fd, 0, SEEK_END);

        char passpos[5];
        sprintf(passpos,"%d",pcounter); //int to string
        fd=open(argv[2],O_RDWR|O_CREAT|O_TRUNC,S_IRWXU);
        write(fd,passpos,3);
    }

我将 str 重新定义为“alpha one”的原因是,即使我试图在 scanf 后使用 fflush 清除缓冲区,fgets 仍然会得到一个“/n”作为输入(我假设)并且当我打印“name”时我得到空白。即使这不是主要问题,任何对此的帮助都是有价值的。

这一切都在一个循环中,所以我想如果我在提示时继续按“1”,我的二进制文件应该如下所示: alpha onealpha one alpha one ...

但是,它看起来像:alpha one,无论我按多少次 1。

与存储计数器的其他二进制文件相同,它会正确更新,因此在第一个循环之后它存储了“9”,但在我期望的第二个循环之后只有“18”:9 18

我尝试完全删除 lseek,并将其设置为 CURR 而不是 END。结果相同。我打开了最大警告,编译时没有收到任何警告。

我应该指出这是家庭作业,所以我不能使用 fopen 等,只能使用系统命令。

这是 updateCounter 函数,以防有人想要运行它:

int updateCounter(int pcounter, char *str){
int m,charcount = 0;
for(m=0; str[m]; m++) {
        charcount ++;
}
printf("chars: %d \n", charcount);

pcounter = pcounter + charcount;
printf("pcounter = %d \n", pcounter);

return pcounter;
}

谢谢你的帮助。

标签: cfilebinaryfileslseek

解决方案


您正在打开带有O_TRUNC标志的文件。这告诉计算机从文件中删除所有数据。如果您不想从文件中删除所有数据,请不要使用 O_TRUNC。

此外,请确保在写入任何数据之前查找文件末尾。否则,您将覆盖文件开头的数据。您可以使用lseek寻找结尾,也可以O_APPEND在打开文件时使用标志自动寻找结尾。


推荐阅读