c-CS50 pset4恢复:fwrite功能中的Seg故障



每当运行程序时,都会出现分段故障。使用printf函数,我已经缩小了seg错误发生在我的fwrite函数中的第二个while循环的第一次迭代中代码fwrite(buffer,sizeof(BYTE(,block,output(的最后一行。我尝试了很多方法,但我无法消除seg错误。知道是什么原因造成的吗?以及如何解决这个问题?

#include <stdio.h>
#include <stdlib.h>
#include <stdint.h>
#include <cs50.h>
#include <string.h>
typedef uint8_t BYTE;
const int block = 512;
int main(int argc, char *argv[])
{
if (argc != 2)
{
printf("Usage: ./recover card.raw");
return 1;
}
//open file for reading
char *infile = argv[1];
FILE *file = fopen(infile, "r");
if (file == NULL)
{
printf("Error while opening file");
return 1;
}
//initializing
BYTE buffer[block];
memset(buffer, 0x00, block);
BYTE x = 0;
memset(&x, 0x00, 1);
BYTE JPEG[3] = {0xff, 0xd8, 0xff};
char filename[8];
int imagecount = 0;
//open file output for writing
FILE* output = NULL;
output = fopen("000.jpg", "w");
while (1)
{
fread(&x, sizeof(BYTE), 1, file);
if (x == JPEG[0])
{
fread(&x, sizeof(BYTE), 1, file);
if (x == JPEG[1])
{
fread(&x, sizeof(BYTE), 1, file);
if (x == JPEG[2])
{
fread(&x, sizeof(BYTE), 1, file);
int y = (int) x;
if ((y >= 224) && (y <= 239))
{
break;
}
}
}
}
}
fwrite(JPEG, sizeof(BYTE), 3, output);
fwrite(&x, sizeof(BYTE), 1, output);
fread(output, sizeof(BYTE), block - 4, file);
while (1)
{
int n = fread(&buffer, sizeof(BYTE), block, file);
if (n == 0)
{
break;
}
if (buffer[0] == JPEG[0] && buffer[1] == JPEG[1] && buffer[2] == JPEG[2] && output != NULL)
{
fclose(output);
imagecount++;
sprintf(filename, "%03i.jpg", imagecount);
output = fopen(filename, "w");
}
printf("z");
fwrite(buffer, sizeof(BYTE), block, output);
printf("z");
}
}

您正在执行fread(output,...,...,file)

也就是说,您正在读取作为outputFILE描述符的缓冲区。可能不是你想要的。。。

请注意,fread的第一个参数是void *指针,因此它非常乐意接受这一点(即没有编译错误(。

换句话说,你正在破坏FILE *output指向的东西。

最新更新