strcmp参数类型错误

时间:2011-08-01 19:31:28

标签: c

我正在尝试不使用isSpace函数,因此唯一想到的是strcpy,但我收到错误

while ( walker > 0 &&   strcmp(a[walker - 1],space_const) )

Warning 86: argument 1 conflicts with formal definition

任何人都知道如何解决此问题? space_constchar初始化为" "

char* strTrim(char* string)
{
 char* a= string;

 char delims[3];
 char space_const[] =" ";
 char syntax_const[]=" \t\n\v";
 size_t walker = strlen ( a );
 strcpy(delims,space_const);
 /* Trim trailing spaces */
 while ( walker > 0 &&   strcmp(a[walker - 1],space_const) )
   --walker; 

 a[walker] = '\0';

 /* Trim leading spaces */
 walker = strspn ( a,syntax_const);
 memmove ( a, a + walker, strlen ( a + walker ) + 1 );
 return extractCmd(a ,space_const );
}

2 个答案:

答案 0 :(得分:6)

您正在尝试比较字符(小整数)和字符串。

char* a= string;
/*... */

strcmp(a[walker - 1], space_const);
         ^ character

strcmp看起来像这样

int strcmp(const char *s1, const char *s2);
                  ^ string        ^ string


你可能想要这样的东西:

(a[walker - 1] == ' ' || a[walker - 1] == '\t' || ..)

你应该写一个函数。但是你最终会重写isspace

为什么不首先使用isspace

答案 1 :(得分:1)

通过在变量a []之后添加括号,您已将其设为char。然后,您必须使用&符号将其取消引用回指针。如:

while ( walker > 0 &&   strnicmp(&a[walker - 1],space_const, strlen(space_const)) ) 

这里要非常小心,因为传入的字符串没有被验证,所以看起来这可能会用于缓冲区溢出。