由于昨天升级不慎,系统崩溃,重新安装之后,相同的程序出现段错误……
#include <stdlib.h>
#include <string.h>
#define M 1000000
#define LEN 100
void transfer(char *in)
{
char * word[M];
int times[M];
float frequency[M];
char * flag = NULL;
//gdb调试到这里出错……
char * source = (char *)malloc(LEN);
char * label = (char *)malloc(LEN);
char * token = (char *)malloc(LEN);
int i = 0;
int j;
int sum = 0;
strcpy(source, strtok(in, " "));
strcpy(label, strtok(NULL, " "));
printf("%s",label);
while(1)
{
flag = strtok(NULL, " ");
if(flag == NULL)
break;
strcpy(token, flag);
word = (char *)malloc(LEN);
strcpy(word, token);
flag = strtok(NULL, " ");
if(flag == NULL)
break;
strcpy(token, flag);
times = atoi(token);
sum += times;
i++;
}
for(j=0;j<i;j++)
{
frequency[j] = times[j]*1.0/sum;
printf(" %s:%f",word[j],frequency[j]);
}
printf("\n");
for(j=0;j<i;j++)
free(word[j]);
free(label);
free(source);
free(token);
}
int main()
{
char * in = (char *)malloc(M);
char * fileName = (char *)malloc(LEN);
freopen("output.txt", "w",stdout);
scanf("%s",fileName);
FILE *fp = fopen(fileName, "r");
while(fgets(in, M-1, fp) != NULL)
{
transfer(in);
}
fclose(fp);
free (in);
free (fileName);
return 0;
}
段错误~~
-
- 帖子: 9
- 注册时间: 2007-06-25 20:18
- 联系:
-
- 帖子: 9
- 注册时间: 2007-06-25 20:18
- 联系:
- eexpress
- 帖子: 58428
- 注册时间: 2005-08-14 21:55
- 来自: 长沙
-
- 帖子: 9
- 注册时间: 2007-06-25 20:18
- 联系:
-
- 帖子: 38
- 注册时间: 2007-09-07 3:08
-
- 帖子: 9
- 注册时间: 2006-11-04 20:58
你在栈中声明了太多占内存很大的变量,导致栈溢出了
注意不要声明几M大小的临时变量,可以用 malloc() 动态分配。
因为在系统中,栈的大小是有限制的,不像堆内存那样可以随便用。
char * word[M];
int times[M];
float frequency[M];
这里消耗了好几M栈内存,建议这里用 malloc 分配。在C/C++ 这种语言中,需要特别注意这种问题。要不然函数多调用几次,一旦栈比较深了以后就出问题
因为在系统中,栈的大小是有限制的,不像堆内存那样可以随便用。
char * word[M];
int times[M];
float frequency[M];
这里消耗了好几M栈内存,建议这里用 malloc 分配。在C/C++ 这种语言中,需要特别注意这种问题。要不然函数多调用几次,一旦栈比较深了以后就出问题