3

まず、次のように 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 を継承しませんでした。しかし、次のように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;
}

で正しい答えを得ましたdata.out。つまり、execv は c++ コードで動作します。

では、execv を Python でも動作させるにはどうすればよいでしょうか? この機能が本当に必要なのですが、誰か教えてもらえますか? どうもありがとう!

data.in以下が含まれます。

1 1
4

1 に答える 1

6

Python コードで、新しい IO ストリームを開き、これらを指すようにsys.stdinおよびsys.stdoutPythonを設定しました。それらには独自のファイル記述子があります (ほとんどの場合、3 と 4)。ただし、標準のファイル記述子 、0および1は変更されず、元の場所を指し続けます。execこれらは、 C++ プログラムで stdin および stdout に入るときに継承される記述子です。

実行する前に、実際のファイル記述子が調整されていることを確認する必要があります。

os.dup2(sys.stdin.fileno(), 0)
os.dup2(sys.stdout.fileno(), 1)
于 2011-12-14T06:09:53.563 に答える