C内核字符串连接和比较

时间:2013-07-09 23:27:14

标签: c string kernel

作为参考,我对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', ...}是一样的还是我在这里遗漏了什么?

3 个答案:

答案 0 :(得分:1)

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

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';

答案 1 :(得分: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"};

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

答案 2 :(得分:1)

继承人为你工作

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);
}