混合声明和代码

9 c declaration compiler-warnings c89

当我使用"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]);
              }
Run Code Online (Sandbox Code Playgroud)

但是,当编译上面的函数用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]);
              }
Run Code Online (Sandbox Code Playgroud)

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

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

dene.c:20:错误:'p1'未声明(首次使用此功能)

dene.c:20:错误:(每个未声明的标识符仅报告一次

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]);
              }
Run Code Online (Sandbox Code Playgroud)

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

dmc*_*kee 14

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

那么,范围块是什么?由{和划定的区域}.

所以在上面的例子中声明

{
   char *p=malloc(sizeof(char)*3); /* ...
Run Code Online (Sandbox Code Playgroud)

是的,因为它会在a {,while 之后立即发生

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

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

  int len=0;...
Run Code Online (Sandbox Code Playgroud)

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

  • 但是,您可以注意到,当您到达匹配的`}`时,在范围中创建的变量会超出范围*,并且在此之后访问它们是错误的. (2认同)