Как наследовать stdin и stdout в python с помощью os.execv () - PullRequest
3 голосов
/ 14 декабря 2011

Сначала я написал код на C ++ следующим образом:

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

Я использую 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)

Однако файл data.out ничего не содержит.То есть дочерний процесс не наследовал stdin и stdout от своего родительского процесса.Но когда я написал код на С ++ следующим образом:

#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;
}

Я получил правильный ответ в data.out, то есть execv работает в коде на С ++.

Итак, чтоЯ должен сделать, чтобы execv также работает в Python?Мне действительно нужна эта функция, кто-нибудь может мне сказать?Большое спасибо!

data.in содержит следующее:

1 1

1 Ответ

6 голосов
/ 14 декабря 2011

В своем коде Python вы открыли новые потоки ввода-вывода и задали sys.stdin и sys.stdout Python имена , чтобы они указывали на них.У них будут свои файловые дескрипторы (скорее всего, 3 и 4).Однако стандартные файловые дескрипторы 0 и 1 останутся без изменений и будут продолжать указывать на свои исходные местоположения.Это дескрипторы, унаследованные, когда вы exec вводите в stdin и stdout в вашей программе на C ++.

Перед выполнением необходимо убедиться, что фактические дескрипторы файлов настроены.

os.dup2(sys.stdin.fileno(), 0)
os.dup2(sys.stdout.fileno(), 1)
...