9

当我用 "gcc -o dene -Wall -ansi -pedantic-errors dene.c" 编译函数时,gcc 不会发出错误。(你能看一下以 char .... 开头的行吗,在 if 循环中)

        static void remove_negation(char *s,char *s1) 
          {
             char **cmainp=malloc(sizeof(char*)*1);   
                        int len=0;int d=0; int i=0;
            cmainp[0]=malloc(sizeof(char)*300);
            len=strlen(s);
           for(i=0;i<len;++i)
             { if(s[i]=='-')
               if(i==0 || s[i-1]==',')
      /*look*/  {char *p=malloc(sizeof(char)*3); /*look*/

                ++i;    p[0]=s[i];   p[1]='\0'; 

              strcat(s1,","); strcat(s1,p); free(p);
               continue;
             }
            cmainp[0][d]=s[i]; 
               ++d;
               } cmainp[0][d+1]='\0'; 


             strcpy(cmainp[0],s);
             free(cmainp[0]);
              }

但是,当使用 gcc 重新格式化上述函数时,gcc 会发出该错误;

“dene.c:10:错误:ISO C90 禁止混合声明和代码”

        static void remove_negation(char *s,char *s1) 
          {
             char **cmainp=malloc(sizeof(char*)*1);    
          /*look*/ cmainp[0]=malloc(sizeof(char)*300); /*look*/
                        int len=0;int d=0; int i=0;

            len=strlen(s);
           for(i=0;i<len;++i)
             { if(s[i]=='-')
               if(i==0 || s[i-1]==',')
        {char *p=malloc(sizeof(char)*3);

                ++i;    p[0]=s[i];   p[1]='\0'; 

              strcat(s1,","); strcat(s1,p); free(p);
               continue;
             }
            cmainp[0][d]=s[i]; 
               ++d;
               } cmainp[0][d+1]='\0'; 


             strcpy(cmainp[0],s);
             free(cmainp[0]);
              }

最后一个,gcc 发出以下错误

dene.c:16: 错误: 'char' 之前的预期表达式</p>

dene.c:20: 错误: 'p1' undeclared (第一次在这个函数中使用)

dene.c:20: error: (每个未声明的标识符只报告一次

dene.c:20:错误:对于它出现的每个函数。)

        static void remove_negation(char *s,char *s1) 
          {
             char **cmainp=malloc(sizeof(char*)*1);    

                        int len=0;int d=0; int i=0;
             cmainp[0]=malloc(sizeof(char)*300); 
            len=strlen(s);
           for(i=0;i<len;++i)
             { if(s[i]=='-')
        /*look*/   char *p=malloc(sizeof(char)*3);   /*look*/
               if(i==0 || s[i-1]==',')
              {

                ++i;    p[0]=s[i];   p[1]='\0'; 

              strcat(s1,","); strcat(s1,p); free(p);
               continue;
             }
            cmainp[0][d]=s[i]; 
               ++d;
               } cmainp[0][d+1]='\0'; 


             strcpy(cmainp[0],s);
             free(cmainp[0]);
              }

问题是为什么它们之间存在差异。

4

4 回答 4

14

在 K&R 和 ANSI c 中,您必须始终将声明放在作用域块的开头。这个要求在 c99 中放宽了。

那么,什么是作用域块?{由和分隔的区域}

所以在你上面的例子中,声明

{
   char *p=malloc(sizeof(char)*3); /* ...

可以,因为它紧跟在 a 之后{,而

{
  char **cmainp=malloc(sizeof(char*)*1);    

  /*look*/ cmainp[0]=malloc(sizeof(char)*300); /*look*/

  int len=0;...

失败,因为分配位于{第二个声明 ( int len=0;) 之间。

于 2010-05-24T10:23:26.380 回答
1

问题是您的标志“-ansi”强加了 ANSI C 的规则,其中声明可能只出现在块的开头,而不是与其他语句交错的任何其他地方。

请注意,在您的第一个示例中,{if 之后的左大括号开始一个新块,因此在那里声明新变量是合法的。在您的第二个示例中,您在与“char **cmainp”相同的块中声明“int len”,但在分配给“cmainp”之后。如果将赋值放在声明之后,那么一切都会好起来的,因为声明将位于块的开头。

于 2010-05-24T10:24:32.377 回答
1

char *p=malloc(sizeof(char)*3)使用您在代码中间定义的“dene.c:10:错误:ISO C90 禁止混合声明和代码”错误。ANSI C 要求声明出现在代码块的开头而不是其他地方。相反,如果您将 char*p放在代码的开头,然后*p=malloc(sizeof(char)*3)在第 10 行,这个“错误”就会消失。

于 2010-05-24T10:25:08.693 回答
0

你必须在做任何事情之前做声明。

于 2012-08-23T13:41:24.337 回答