0

「ls -l | sort -n」の動作をシミュレートするプログラムを実装することになっています。コードを作成しましたが、ロジックによれば、すべてが完全に機能するはずですが、そうではありません。ここ数時間、これをデバッグしようとしてきたので、追加の入力があれば大歓迎です。コードは次のとおりです。

#include <unistd.h>
#include <stdio.h>
#include <stdlib.h>
#include <sys/types.h>

int main(int argc, char *argv[])
{
    int fd[2];
    int errcheck;
    errcheck = pipe(fd);
    printf("Errcheck after pipe call: %d\n", errcheck);
    pid_t childpid;
    childpid=fork();
    if(childpid==0)
    {
        printf("Entering child\n");
        errcheck = dup2(fd[1], STDOUT_FILENO);
        printf("Errcheck after dup2 child: %d\n", errcheck);
        close(fd[0]);
        execl("bin/ls", "ls", "-l", NULL);
    }
    printf("Before sort call\n");
    errcheck = dup2(fd[0], STDIN_FILENO);
    printf("Errcheck after dup2 parent: %d\n", errcheck);
    close(fd[1]);
    execl("/usr/bin/sort", "sort", "-n", NULL);
}

「Entering child」の後にプログラムがスタックします。子の dup2 呼び出しが完了しない理由が本当にわかりません...

よろしくお願いします。

4

1 に答える 1

0

ファイルの一覧表示に dirent を使用しない理由はありますopendir readdirか? それとも学校の宿題ですか?本番用の場合は、dirent.h と stat.h の使用を検討してください。

学業については、あなたが何をする必要があるかはあなたの教授次第です。その場合は、これを宿題とラベル付けしてください。

于 2012-05-19T02:37:14.450 に答える