3

所以,我正在尝试运行一个后台进程并从中执行 execvp。当我输入 cp /path/file /var/tmp 时,该过程不会复制文件。

这是我的参考代码:

void cmd_bg(char command[])
{
        pid_t process_id = 0;
        pid_t sid = 0;
        char* argv[512];
        getArgv(command,argv);
        // Create child process
        process_id = fork();
        // Indication of fork() failure
        if (process_id < 0)
        {
                printf("fork failed!\n");
                // Return failure in exit status
                exit(1);
        }
        // PARENT PROCESS. Need to kill it.
        if (process_id > 0)
        {
                printf("process_id of child process %d \n", process_id);
                // return success in exit status
                exit(0);
        }
        //unmask the file mode
        umask(0);
        //set new session
        sid = setsid();
        if(sid < 0)
        {
                // Return failure
                exit(1);
        }
        // Change the current working directory to root.
        chdir("/");
        // Close stdin. stdout and stderr
        close(STDIN_FILENO);
        close(STDOUT_FILENO);
        close(STDERR_FILENO);


        execvp(argv[0],argv);

        }
}
void getArgv(char command[], char* argv[512])
{
        char *token;
        int count = 0;
        int pid = 0;
        int ex = 0;
        char *absPath;
        char pwdtemp[512];
        strcpy(pwdtemp,pwd);

        token = strtok(command, " ");
        while(token!=NULL)
        {
                argv[count++] = token;
                printf("%s\n",argv[count-1]);
                token = strtok(NULL," ");
        }
        argv[count] = '\0';
}

我真诚地希望有人能帮助我。谢谢!

编辑:我找到了解决方案。我不能自我回答,因为我还没有 100 次代表。无论如何,对于未来可能会查看此主题的人:

好的。我解决了这个问题。

首先我注释掉了

close(STDIN_FILENO);
close(STDOUT_FILENO);
close(STDERR_FILENO);
chdir("/");

接下来,我没有直接调用 cmd_bg,而是创建了:

void temp1(char command[])
{
    int pid = fork();
    if(pid==0)
        cmd_bg(command);

    else
        waitpid(-1, NULL, 0);
}

它现在似乎工作了!非常感谢您的投入!

4

3 回答 3

0

我会检查 execvp 是否返回(它只在错误时返回),并查看它产生的 errno。这可能会帮助您追踪问题。

于 2012-04-25T12:25:49.483 回答
0

你有没有机会调用你的程序cp?如果是这种情况,您execvp()将一遍又一遍地调用该程序,而不是/bin/cp. 获得完整的代码也很有帮助。

于 2012-04-25T13:00:28.987 回答
0

你试过不关闭标准输入、标准输出、标准错误吗

于 2012-04-25T12:22:10.650 回答