我真的迷失在这里。构建Linux shell,处理外部命令。我正在尝试创建一个新进程然后执行命令。对exec(),fork(),pipe()和dup()来说很新,但我确定我需要它们。
基本上我的问题是:将参数传递给exec的最佳方法是什么?我知道有很多选项,但如果我有一个包含“ls -l”的字符串向量,我该如何将其传递给execute?我应该将其重新解析为“ls”和“-l”吗?
我已经有fork()创建子进程,但我不知道如何运行exec()。
在一个有点相关的说明中,我应该把什么放在fork()
的waitpid部分 pid_t pid;
int status;
pid = fork();
if (pid < 0)
{
cout << "Fork failed." << endl;
}
else if (pid == 0)
{
execv("/bin/sh", (VECTOR OF COMMANDS?));
_exit (EXIT_FAILURE);
}
else
{
if (waitpid (pid, &status, 0) == pid)
{
cout << "huh?" << endl;
}
else
{
cout << "Error." << endl;
}
}
下一个障碍是管道,但是当我到达那里时,我会越过那座桥。
编辑:
对于它的价值,这是我遇到麻烦的解析和调用。带有“ * *”的行似乎是给我带来问题的
const char *args [1024];
string::iterator it5;
size_t pos5;
for (it5=origCstr.begin(); it5 < origCstr.end(); it5++)
{
string::iterator it2;
pos5 = origCstr.find(' ');
if (pos5 == string::npos)
{
tmpChar = origCstr.c_str();
args[argCount] = tmpChar;
argCount++;
break;
}
it2 = it5 + pos5;
tmpCstr = origCstr.substr(0, pos5);
tmpChar = tmpCstr.c_str();
args[argCount] = tmpChar;
origCstr.erase(it5, it2+1);
argCount++;
}
tmpChar = origCstr.c_str();
args[argCount] = tmpChar;
argCount++;
pid_t pid;
int status;
pid = fork();
if (pid < 0)
{
cout << "Fork failed." << endl;
}
else if (pid == 0)
{
execv("/bin/", args); ****
_exit (EXIT_FAILURE);
}
else
{
if (waitpid (pid, &status, 0) == pid)
{
cout << "huh?" << endl;
}
else
{
cout << "Error." << endl;
}
}
答案 0 :(得分:1)
您需要调用'execv',以便制作包含选项的char*[]
。 “ls”和“-l”各自在数组中获得自己的插槽。
你必须抛弃const,或者使用char`char const * []'数组,然后抛弃const,将它传递给execv。通常,这些系统调用的声明对C ++有点不友好。
请参阅a stack overflow question on this subject。
http://www.yolinux.com/TUTORIALS/ForkExecProcesses.html有一个合理的教程。
粗略地说:
char * exec_args[1024];
int arg_count = 0;
std::vector<std::string> theArgs;
exec_args[arg_count++] = "/bin/whatever"; // leave command in argv[0]
for (int x = 0; x < theArgs.size(); x++) {
exec_args[arg_count++] = strdup(theArgs[x].c_str());
}
exec_args[arg_count++] = 0; // tell it when to stop!
execv("/bin/whatever", exec_args);