int main(int argc ,const char* argv[]) { FILE* fp; int buff[1024]; int len; unsigned int cnt = 0; fopen(argv[1],"r+"); while(!feof(fp)) { len = fread (buff,1,1024,fp); cnt += len; fprintf(stdout,"这个文件共有%d字节",len); memset(buff,0,1024); } fprintf(stdout,"这个文件共有%d字节",len); fclose(fp); return 0; }我用这段代码尝试去读出一个文件的大小,但是他为什么会报Segmentation fault (core dumped)的错误
时间: 2023-12-30 09:06:27 浏览: 74
这段代码中出现了几个问题:
1. `fopen`函数没有进行错误检查,可能导致文件打开失败而出现错误
2. `fp`指针没有被赋值,导致在读取文件时出现错误
3. 在循环中,应该累加所有读取的字节数,而不是每次只输出当前读取的字节数
4. 最后一次读取的字节数可能小于1024,应该在循环结束后输出累加的所有字节数
5. `memset`函数的作用不清楚,可能会导致数据被清空而出现错误
下面是修改后的代码:
```
#include <stdio.h>
int main(int argc, char* argv[]) {
FILE* fp;
int buff[1024];
int len;
unsigned int cnt = 0;
fp = fopen(argv[1], "r");
if (fp == NULL) {
fprintf(stderr, "无法打开文件\n");
return 1;
}
while (!feof(fp)) {
len = fread(buff, 1, 1024, fp);
if (len == 0) {
break;
}
cnt += len;
}
fprintf(stdout, "这个文件共有%d字节\n", cnt);
fclose(fp);
return 0;
}
```
修改后的代码中,我们首先对`fopen`函数的返回值进行了错误检查。在循环中,我们累加所有读取的字节数,并且添加了一个判断,以防止最后一次读取的字节数小于1024。最后,我们在循环结束后输出累加的所有字节数。
阅读全文