如何通过使用os.execv()在python中继承stdin和stdout

luy*_*619 3 python stdin fork stdout execv

首先,我编写了一个c ++代码,如下所示:

#include <cstdio>
int main()
{
    int a,b;
    while(scanf("%d %d",&a,&b) == 2)
        printf("%d\n",a+b);
    return 0;
}
Run Code Online (Sandbox Code Playgroud)

g++ -o a a.cpp习惯于使它复杂化。

之后,我编写了如下的python代码:

import os,sys
sys.stdin = open("./data.in","r")
sys.stdout = open("./data.out","w")
pid = os.fork()
if pid == 0:
    cmd = ["./a","./a"]
    os.execv(cmd[0],cmd)
Run Code Online (Sandbox Code Playgroud)

但是,该data.out文件不包含任何内容。也就是说,子进程没有从其父进程继承stdin和stdout。但是当我编写如下的c ++代码时:

#include<unistd.h>
#include<cstdio>
int main()
{
    freopen("data.in","r",stdin);a
    freopen("data.out","w",stdout);
    int pid = fork();
    if(pid == 0)
    {
        char* cmd[]= {"./a","./a"};
        execv(cmd[0],cmd);
    }
    return 0;
}
Run Code Online (Sandbox Code Playgroud)

我在中得到了正确的答案,data.out也就是说execv在c ++代码中有效。

那么,我该怎么做才能让execv也能在python中工作?我真的需要此功能才能工作,有人可以告诉我吗?非常感谢!

data.in 包含以下内容:

1 1
Run Code Online (Sandbox Code Playgroud)

Mat*_*ner 6

在python代码中,您打开了新的IO流,并设置sys.stdinsys.stdoutPython 名称以指向这些流。它们将具有自己的文件描述符(最可能是3和4)。但是,标准文件描述符01将保持不变,并继续指向其原始位置。这些是您exec在C ++程序中进入stdin和stdout 时继承的描述符。

您需要确保在执行之前调整了实际的文件描述符。

os.dup2(sys.stdin.fileno(), 0)
os.dup2(sys.stdout.fileno(), 1)
Run Code Online (Sandbox Code Playgroud)