繁体   English   中英

比较 C 中动态分配的字符串

[英]Comparing dynamically allocated strings in C

我正在处理一个案例,我正在根据另一个 function 的返回值动态填充一个 char 数组。

在某些时候,我想将传入值与 static 字符串进行比较并触发一个操作。

出于某种原因,我无法让strcmp function 工作。 这是我的代码和相应的 output。

代码:

#include<stdio.h>
#include<stdlib.h>
#include<string.h>

char* word_generator(int selector)
{
    switch(selector)
        {
            case 0:
                return "a";
                break;
            case 1:
                return "jk";
                break;
            case 2:
                return "dfr";
                break;
            case 3:
                return "sbjk";
                break;
            default:
                printf("ERROR: Request out of range!\n");
    }
    return "";
}


int main () {
    for(int i = 0; i < 4; i++)
    {
        printf("Test string[%d]: %s\n", i, word_generator(i));
        printf("\t__STRLEN: %lu\n", strlen(word_generator(i)));

        char* input_char_buffer = malloc(strlen(word_generator(i))+1);
        strcpy(input_char_buffer, word_generator(i));
    
        printf("\tCurrent buffer (value: %s, length: %zu)\n", input_char_buffer, strlen(input_char_buffer));

        char key[] = "dfr";
        printf("\tCurrent key (value: %s, length: %zu)\n", key, strlen(key));

        /* if(strlen(input_char_buffer) == strlen(key)) */
        /* { */
        /*     printf("\t\tOK\n"); */
        /* } */

        int ret;
        ret = strcmp(input_char_buffer, key);
        printf("\t__STRCMP: %d\n", ret);

        if(ret == 1)
        {
            printf("\t\tOK\n");
        }

        // Clean-up.
        free(input_char_buffer);
        input_char_buffer = NULL;
    }

    return 0;
}

OUTPUT:

Test string[0]: a
    __STRLEN: 1
    Current buffer (value: a, length: 1)
    Current key (value: dfr, length: 3)
    __STRCMP: -3
Test string[1]: jk
    __STRLEN: 2
    Current buffer (value: jk, length: 2)
    Current key (value: dfr, length: 3)
    __STRCMP: 6
Test string[2]: dfr
    __STRLEN: 3
    Current buffer (value: dfr, length: 3)
    Current key (value: dfr, length: 3)
    __STRCMP: 0
Test string[3]: sbjk
    __STRLEN: 4
    Current buffer (value: sbjk, length: 4)
    Current key (value: dfr, length: 3)
    __STRCMP: 15

如您所见,调试位是正确的值,但由于某种原因strcmp返回垃圾值。

别担心,这些数字不是垃圾,这就是strcmp的工作原理。

只要两个字符串匹配, strcmp就返回0 ,如果不匹配,它返回 ASCII 表中两个字符串的第一个char之间的差异。

例如:

dfrd的值在 ASCII 表中为100 ,而sbjks为 115。因此, 115 - 100 = 15 ,这就是您获得的回报。

您似乎只想检查两个字符串是否相等。 为此,我建议您使用!strcmp()而不是strcmp 这样,如果字符串匹配则为1 ,否则0 您可以稍后检查逻辑操作数! 有效以及为什么会这样。

您可以看到更改生效:

Test string[0]: a
    __STRLEN: 1
    Current buffer (value: a, length: 1)
    Current key (value: dfr, length: 3)
    __STRCMP: 0
Test string[1]: jk
    __STRLEN: 2
    Current buffer (value: jk, length: 2)
    Current key (value: dfr, length: 3)
    __STRCMP: 0
Test string[2]: dfr
    __STRLEN: 3
    Current buffer (value: dfr, length: 3)
    Current key (value: dfr, length: 3)
    __STRCMP: 1
        OK
Test string[3]: sbjk
    __STRLEN: 4
    Current buffer (value: sbjk, length: 4)
    Current key (value: dfr, length: 3)
    __STRCMP: 0

暂无
暂无

声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.

 
粤ICP备18138465号  © 2020-2024 STACKOOM.COM