CS50 PSET4 RECOVER-无法恢复001.jpg,并且恢复的文件0049.jpg不匹配

时间:2020-06-11 15:59:25

标签: pointers cs50 recovery

我正在尝试对CS50的pset4进行“恢复”问题。

看来我能够检索除001.jpg以外的所有图像。考虑到check50告诉我以下内容,我怀疑这进一步导致文件编号不一致:-

:)正确恢复000.jpg

:((可以正确恢复中间图像 找不到001.jpg

:((可正确恢复049.jpg 恢复的图片不匹配

为清楚起见,我能够检索000.jpg,然后立即检索文件002.jpg至0050.jpg。跟踪jpeg文件数量的计数器似乎正在工作,因此我很困惑为什么可能会跳过001。

如果有人可以帮助我确定我的代码是否存在逻辑错误,将不胜感激。 我有一种预感,当程序立即跳转到“ else”分支(其中前4个字节不是JPEG标头)时,会出现一些问题?提前非常感谢大家!

这是我的代码:

#include <stdio.h>
#include <stdlib.h>
#include <stdint.h>

typedef uint8_t BYTE;

int main(int argc, char *argv[])
{
  //Check for 1 command line argument
  if (argc != 2)
  {
    printf("Usage: ./recover image\n");
    return 1;
   }

//Opening forensic image file & getting its file pointer called "raw"
FILE *raw = fopen(argv[1], "r");

if (raw == NULL)        //Checking if pointer returns a null value
{
    return 1;
}

//Create counter to keep track of no. of JPEG files
int counter = 0;

//Creating a buffer with a size of 512 x BYTES
BYTE buffer[512];

//Creating a string for file name
char filename[8];

while (fread(buffer, sizeof(BYTE), 512, raw) == 512)
{

    //Checking if first 4 bytes are JPEG headers
    if (buffer[0] == 0xff &&
        buffer[1] == 0xd8 &&
        buffer[2] == 0xff &&
        (buffer[3] & 0xf0) == 0xe0)
    {
        //If it is first JPEG file
        if (counter == 0)
        {
            //Determine file name
            sprintf(filename, "%03i.jpg", counter);

            //Open new file
            FILE *output = fopen(filename, "w");

            //Write to new file
            fwrite(buffer, sizeof(BYTE), 512, output);

            //Increment JPEG file count by 1
            counter++;

            //Close file
            fclose(output);
        }
        else    //if not first JPEG file (i.e. counter !=0)
        {
            //Increment JPEG count first so that file name will be +1 as well
            counter++;

            //Determine next file name
            sprintf(filename, "%03i.jpg", counter);

            //Open new file
            FILE *output = fopen(filename, "w");

            //Write to new file
            fwrite(buffer, sizeof(BYTE), 512, output);

            //Close file
            fclose(output);
        }
    }
    else    //if first 4 bytes are not JPEG headers
    {
        //Open previous file (because there is no count increment)
        FILE *output = fopen(filename, "a");    //used 'a' instead to amend instead of 
                                                  overwriting previous file with 'w'

        //Write to previous file
        fwrite(buffer, sizeof(BYTE), 512, output);

        //close file
        fclose(output);
    }

    //For checking - to remove later
    printf("%i\n", counter);

}
fclose(raw);
return 0;

}

1 个答案:

答案 0 :(得分:0)

 FILE *output = fopen(filename, "a");    //used 'a' instead to amend instead of 
                                                  overwriting previous file with 'w'

filename未初始化。