【发布时间】:2017-01-12 21:35:46
【问题描述】:
我意识到标题令人困惑,想不出更清晰的措辞。基本上,我在 strtok 循环内调用 strtok 循环,但是当内部 strtok 函数从 runCommand 返回时,我的第一个 strtok 循环停止。它只是退出循环,即使第一个分号后面还有其他参数。当我不调用 runCommand() 时,它会按预期工作,并解析我所有用分号分隔的命令。
这段代码的目标是解析一行以分号分隔的命令,然后解析命令和命令参数,以便稍后进入 execvp。这是我唯一遇到问题的部分。这里是:
void parseCommand(char *userLine)
{
if(strchr(userLine, ';'))
{
// Get first token
token = strtok(userLine, ";");
// Loop through all tokens
while(token != NULL)
{
// Make a copy
char *copy = malloc(strlen(token) + 1);
strcpy(copy, token);
runCommand(copy);
free(copy);
printf("process returned!\n");
token = strtok(NULL, ";");
}
}
}
void runCommand(char *token)
{
char *args[20];
char **command = args;
//Tokenize each command based on space
char *temp = strtok(token, " \n");
while (temp != NULL)
{
*command++ = temp;
temp = strtok(NULL, " \n");
}
*command = NULL;
// code for fork and execvp here
}
谁能解释为什么 runCommand 搞砸了我的第一个函数的解析?我真的不明白为什么它不能使用我的原始令牌的副本。可能很简单,但我已经看了太久了?
【问题讨论】:
-
“我在 strtok 循环中调用了 strtok 循环” - 不能这样做。
strtok的设计很烂。 -
是的,你不能像那样“递归地”使用
strtok——一旦你传递了一个新的、非NULL的参数,它就会完全忘记之前的参数。您必须以广度优先而非深度优先处理您的代币。