C - 字符* 数组初始化



我有这个数组:

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] = '\0'

而不是s[len+1] = '\0';。正如其他用户所说,szo 永远不会初始化。它指向一个随机位置,该位置可能是/可能不是可访问的位置。导致分段冲突

相关内容

  • 没有找到相关文章

最新更新