3

作为参考,我对 strcat 和 strcmp 的实现是:

char *
strcat(char *dest, const char *src)
{
    int i,j;
    for (i = 0; dest[i] != '\0'; i++)
        ;
    for (j = 0; src[j] != '\0'; j++)
        dest[i+j] = src[j];
    dest[i+j] = '\0';
    return dest;
}

int strcmp(const char* s1, const char* s2)
{
    while(*s1 && (*s1==*s2))
        s1++,s2++;
    return *(const unsigned char*)s1-*(const unsigned char*)s2;
}

我正在研究内核,并且遇到了几个问题。基本上我正在构建一个这样的字符串:

unsigned char current_cmd[100];

    char tmp[] = {kbdus[scancode], '\0'};
    if (scancode != 0x1C) // enter key
        strcat((char*)current_cmd, tmp);

然后我进行比较以查看它是否与命令匹配:

if (strcmp((const char*)cmd, "help") == 0)
    puts((unsigned char*)"You can't do anything yet.\n");

然后我做:

current_cmd = (unsigned char)'\0';

重置它以供使用。

它有效,但我真的不明白为什么或如何。谁能给我解释为什么我正在做的工作以及我的代码是否有问题?

第三,是char check[10] = {"help"};一样{'h', 'e', 'l', 'p', ...}的还是我在这里遗漏了什么?

4

3 回答 3

2

为什么不能和文字比较?将您的代码更改为以下内容:

unsigned char current_cmd[100];

char tmp[] = {kbdus[scancode], '\0'};
if (scancode != 0x1C) // enter key
    strcat((char*)current_cmd, tmp);

if (strcmp((const char*)cmd, "help") == 0)
    printf("You can't do anything yet.\n");

current_cmd[0] = '\0';
于 2013-07-09T23:34:14.863 回答
1

current_cmd = (unsigned char)'\0'; 错了,current_cmd是一个数组,不能lvable,可以用current_cmd[0] = '\0'代替重置一个字符串。

char check[10] = "help";

是相同的:

char check[10] = {'h', 'e', 'l', 'p', '\0'};

char check[10] = {"help"};

是错误的,因为它意味着一个字符串数组,而不是字符。

于 2013-07-10T03:19:55.753 回答
1

这是适合您的工作 strcmp

int             my_strcmp(char *str1, char *str2)
{
  int           i;

  i = 0;
  while (str1[i] || str2[i])
    {
      if (str1[i] != str2[i])
        return (str1[i] - str2[i]);
      i++;
    }
  return (0);
}
于 2013-07-16T07:46:13.480 回答