我有这个数组:
char *tags[100];
如果我这样做:
tags[0]="something";
它有效(至少没有错误)。但是,for 循环中的相同代码不会。
int j=0;
for(j; j<100; ++j)
{
tags[j]="something";
}
它说"分段错误"。这是怎麽?
更新:整个代码:
#include <stdio.h>
#include <stdlib.h>
#include <string.h>
void append(char* s, char c)
{
int len = strlen(s);
s[len] = c;
s[len+1] = ' ';
}
int main()
{
int istag;
FILE *fopen(), *fp;
int i;
fp = fopen("oldal.html","r");
i= getc(fp) ;
char* szo;
int index=0;
char *tags[100];
int j=0;
for(j; j<100; ++j)
{
tags[j]="something";
}
while (i!= EOF)
{
i = getc(fp);
char c=i;
if(c=='<')
{
istag=1;
}
if(c=='>')
{
istag=0;
index++;
//printf("tag vege: %s %d",tags[index],index);
}
if(istag)
{
//append(tags[index],'a');
}
append(szo,c);
}
//printf("%s",szo);
fclose(fp);
return 0;
}
你的代码调用你的append()函数将数据附加到szo
,但szo
从未初始化过,并且包含任何恰好在声明它的堆栈上的值。
谁知道它写信到哪里。这几乎可以肯定是问题的原因。
通过将szo
指向足够大小的字符缓冲区来初始化。请记住使其足够大,以容纳附加的数据和终止符。
这意味着代码中的其他地方存在错误。 您发布的代码中没有错误,讨论结束。
更新:叹息
s[len+1] = ' ';
是错误的。
请在调试器中运行您的代码,以查看将来错误产生的行 - 因为它甚至不是您发布的代码中的一行。
分割错误很可能来自行append(szo,c);
,因为此时szo
是一个单元化指针,并且您正在将其传递到一个函数中,该函数尝试使用指针派生要写入的内存位置。
而不是s[len+1] = '\0';。正如其他用户所说,szo 永远不会初始化。它指向一个随机位置,该位置可能是/可能不是可访问的位置。导致分段冲突