我正在为系统编程类(class)开发自定义 shell。我们被指示实现内置的 setenv()
和 unsetenv()
命令,并提示检查 putenv()的手册页
。
我的问题是 setenv(char*, char*, int)
和 putenv(char*)
似乎根本不起作用。我执行输入命令的代码如下:
//... skipping past stuff for IO redirection
pid = fork();
if(pid == 0){
//child
if(!strcmp(_simpleCommands[0]->_arguments[0],"printenv")){
//check if command is "printenv"
extern char **environ;
int i;
for(i = 0; environ[i] != NULL; i++){
printf("%s\n",environ[i]);
}
exit(0);
}
if(!strcmp(_simpleCommands[0]->_arguments[0],"setenv")){
//if command is "setenv" get parameters char* A, char* B
char * p = _simpleCommands[0]->_arguments[1];
char * s = _simpleCommands[0]->_arguments[2];
//putenv(char* s) needs to be formatted A=B; A is variable B is value
char param[strlen(p) + strlen(s) + 1];
strcat(param,p);
strcat(param,"=");
strcat(param,s);
putenv(param);
//setenv(p,s,1);
exit(0);
}
if(!strcmp(_simpleCommands[0]->_arguments[0],"unsetenv")){
//remove environment variable
unsetenv(_simpleCommands[0]->_arguments[0]);
exit(0);
}
//execute command
execvp(_simpleCommands[0]->_arguments[0],_simpleCommands->_arguments);
perror("-myshell");
_exit(1);
}
//omitting restore IO defaults...
如果我运行 printenv
它会正常工作,但是如果我尝试使用 putenv()
或 setenv()
设置一个新变量我的 printenv()
命令返回完全相同的东西,所以它似乎没有工作。
作为旁注,问题可能不在于函数或我如何调用它们,因为我的 shell 正在执行命令,就好像它必须格式化通配符(*
或 ?
) 我不确定应该发生什么。
最佳答案
在检查命令行之前,您似乎无条件地调用了 fork
。但是一些 shell 内置命令需要在 parent 进程中运行,以便它们的效果持续存在。所有操纵环境的内置函数都属于这一类。
顺便说一句,如果我正在编写 shell,我不会尝试使用 C 库的环境操作函数。我会使用三个参数 main
,将 envp
复制到我完全控制的数据结构中,然后将其反馈给 execve
。这部分是因为我是一个控制狂,部分是因为它几乎不可能用 setenv
和/或 putenv
做任何复杂的事情并且没有内存泄漏。参见 this older SO question血淋淋的细节。
关于c++ - setenv, unsetenv, putenv,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/7669409/