嗨,大家好,我在使用以字符串作为参数引用的函数时遇到了一些问题。我读到您应该为此使用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(¤tCommand, 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¯ˇø.
我显然想要输入的字符串的第二个单词,但是我做错了。
谢谢!
最佳答案
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);
}
关于c - 通过双指针引用调用字符串,我们在Stack Overflow上找到一个类似的问题:https://stackoverflow.com/questions/10166406/