通过引用使用双指针调用字符串

时间:2012-04-15 21:44:24

标签: c string pass-by-reference

大家好我在使用带有字符串引用的函数作为参数时遇到了一些问题。我读到你应该使用e双指针,但我不能让它工作。 这是(部分)我的代码。

enum errCode { ERR_NONE = 0, ERR_EMPTY, ERR_FULL, ERR_MEM, ERR_INIT, ERR_COMMAND, ERR_UNDEFINED };
typedef enum errCode ErrCode;

typedef enum {
    no = 0, add, del, src, show, exit
} Command;

int main(void) {
    char stringval[50];
    char stringval2[50];
    ErrCode err;
    Command currentCommand = no;

    printf("Enter a command\n");

    if (fgets(stringval, 50, stdin) != NULL) {
        char *p;
        if ((p = strchr(stringval, '\n')) != NULL)
            *p = '\0';
    }

    ErrHandler(
            extractCommand(&currentCommand, stringval, &stringval2)
            );

    printf("stringval 2 = %s.\n", stringval2);

    return 0;
}

ErrCode extractCommand(Command *command, char *inputString, char **outputString) {

    char *strTemp;
    char *strTemp2;

    //Get the first word of the string
    strTemp = strtok(inputString, " ");

    strTemp2 = strtok(NULL, " ");
    *outputString = strTemp2;

    //Check if it equals a command
    if (strcmp(strTemp, "exit") == 0) {
        *command = exit;
        return ERR_NONE;
    } else if (strcmp(strTemp, "add") == 0) {
        *command = add;
        return ERR_NONE;
    } else if (strcmp(strTemp, "del") == 0) {
        *command = del;
        return ERR_NONE;
    } else if (strcmp(strTemp, "src") == 0) {
        *command = src;
        return ERR_NONE;
    } else if (strcmp(strTemp, "show") == 0) {
        *command = show;
        return ERR_NONE;
    } else {
        *command = no;
        printf("%s", strTemp);
        return ERR_COMMAND;
    }
}

这就是我的输出:

Enter a command
add this is a test
stringval 2 = z˜ˇøÀo‡èK‡èT¯ˇø.

我显然想要输入字符串的第二个字,但我做错了。 谢谢你的帮助!

1 个答案:

答案 0 :(得分:2)

stringVal2未初始化且永远不会填充:这就是打印垃圾的原因。在这种情况下,无需传递char**,传递char*即可。但是,这个:

outputString = strTemp2;

不会将strTemp2的内容复制到outputString:它会使outputString指向与strTemp2相同的地址:使用strcpy()


例如,当该函数为参数分配新缓冲区时,通常会将一个双指针char**传递给函数(在发布的代码中不是这种情况):

char* buf = NULL;
my_alloc(&buf);

void my_alloc(char** p)
{
    *p = malloc(10);
}