pset4 cs50 recover.c 指导
pset4 cs50 recover.c guidance
我可以使用 cs50 中的一些帮助来解决这个问题集。每当我的代码遇到 while 循环时,fread 函数 returns 0。我似乎无法理解为什么会这样。甚至在我 运行 解决这个问题之前,我的代码就没有按照我的期望工作,所以如果有任何其他提示,那将非常有帮助。
#include <stdio.h>
#include <stdlib.h>
#include <stdint.h>
#include <stdbool.h>
//PROTOTYPES
bool check(uint8_t block[]);
int main(int argc, char* argv[])
{
FILE* inptr = fopen("card.raw", "r"); //open up the card.raw file for reading
if(inptr == NULL)
{
fclose(inptr);
printf("Could not open the card data.\n");
return 1;
}
FILE* outptr;
int jpegCount = 0;
bool foundFirstJpg = false;// flag to denote wheather the first jpg has been found
char str[10]; //to hold the jpg name
sprintf(str, "%i.jpg", jpegCount); //puts the image name in str
jpegCount ++;
outptr = fopen(str, "w"); //Create a new jpeg for each image
uint8_t block[512]; // a tempory block to hold 512 bytes of info
while(fread(block, sizeof(block), 1, inptr) == 1) //read 512 bytes of info at a time from the inptr)
{
printf("hello\n");
if(check(block)) //if I have found a jpg
{
if(foundFirstJpg) //if its not my first jpg
{
fclose(outptr); //close the previous jpg file
sprintf(str, "%i.jpg", jpegCount); //puts the image name in str
outptr = fopen(str, "w"); //Create a new jpeg for each image
jpegCount ++;
fwrite(block, sizeof(block), 1, outptr); //write the block to the image file
}
else
{
fwrite(block, sizeof(block), 1, outptr); //write first block to the image file
foundFirstJpg = true;
}
}
else //if this is not a jpg
{
if(foundFirstJpg) //check if we have found our first jpg
{
fwrite(block, sizeof(block), 1, outptr); //write 512 bytes to the current image file
}
}
}
if (outptr)
{
fclose(outptr);
}
fclose(inptr);
return 0;
}
//function to check if this is the start or end of a jpg
bool check(uint8_t block[])
{
bool isJpg = true; //boolean value to be returned
if (block[0] != 0xff || block[1] != 0xd8 || block[2] != 0xff) //checks if the first 3 bytes are those that represent a jpg
{
isJpg = false;
}
if (block[3] < 0xe0 || block[3] > 0xef) //checks if the fourth byte also represents a jpg
{
isJpg = false;
}
return isJpg;
}
您应该以二进制模式打开这些文件:
FILE *inptr = fopen("card.raw", "rb");
...
outptr = fopen(str, "wb");
如果 card.raw
少于 512 字节,fread
将 return 0
.
我可以使用 cs50 中的一些帮助来解决这个问题集。每当我的代码遇到 while 循环时,fread 函数 returns 0。我似乎无法理解为什么会这样。甚至在我 运行 解决这个问题之前,我的代码就没有按照我的期望工作,所以如果有任何其他提示,那将非常有帮助。
#include <stdio.h>
#include <stdlib.h>
#include <stdint.h>
#include <stdbool.h>
//PROTOTYPES
bool check(uint8_t block[]);
int main(int argc, char* argv[])
{
FILE* inptr = fopen("card.raw", "r"); //open up the card.raw file for reading
if(inptr == NULL)
{
fclose(inptr);
printf("Could not open the card data.\n");
return 1;
}
FILE* outptr;
int jpegCount = 0;
bool foundFirstJpg = false;// flag to denote wheather the first jpg has been found
char str[10]; //to hold the jpg name
sprintf(str, "%i.jpg", jpegCount); //puts the image name in str
jpegCount ++;
outptr = fopen(str, "w"); //Create a new jpeg for each image
uint8_t block[512]; // a tempory block to hold 512 bytes of info
while(fread(block, sizeof(block), 1, inptr) == 1) //read 512 bytes of info at a time from the inptr)
{
printf("hello\n");
if(check(block)) //if I have found a jpg
{
if(foundFirstJpg) //if its not my first jpg
{
fclose(outptr); //close the previous jpg file
sprintf(str, "%i.jpg", jpegCount); //puts the image name in str
outptr = fopen(str, "w"); //Create a new jpeg for each image
jpegCount ++;
fwrite(block, sizeof(block), 1, outptr); //write the block to the image file
}
else
{
fwrite(block, sizeof(block), 1, outptr); //write first block to the image file
foundFirstJpg = true;
}
}
else //if this is not a jpg
{
if(foundFirstJpg) //check if we have found our first jpg
{
fwrite(block, sizeof(block), 1, outptr); //write 512 bytes to the current image file
}
}
}
if (outptr)
{
fclose(outptr);
}
fclose(inptr);
return 0;
}
//function to check if this is the start or end of a jpg
bool check(uint8_t block[])
{
bool isJpg = true; //boolean value to be returned
if (block[0] != 0xff || block[1] != 0xd8 || block[2] != 0xff) //checks if the first 3 bytes are those that represent a jpg
{
isJpg = false;
}
if (block[3] < 0xe0 || block[3] > 0xef) //checks if the fourth byte also represents a jpg
{
isJpg = false;
}
return isJpg;
}
您应该以二进制模式打开这些文件:
FILE *inptr = fopen("card.raw", "rb");
...
outptr = fopen(str, "wb");
如果 card.raw
少于 512 字节,fread
将 return 0
.