Grep 永不返回
Grep never returning
我正在尝试使用 execvp
到 运行 grep
。这个程序背后的想法是 fork 一个子进程,使子进程 sort
成为一个名为 sortfile 的文件,然后父进程将在排序后的输出上使用 grep
。下面是我的代码。
#include <stdio.h>
#include <unistd.h>
#include <sys/types.h>
#include <sys/wait.h>
#define READ 0
#define WRITE 1
int main(int argc, char* argv) {
pid_t cpid;
int status;
int pipefd[2];
pipe(pipefd);
char* args[] = {"grep", "f", NULL};
cpid = fork();
if(cpid == 0) {
dup2(pipefd[READ], READ);
dup2(pipefd[WRITE], WRITE);
close(pipefd[READ]);
close(pipefd[WRITE]);
if(execlp("sort", "sort", "sortfile", NULL) == -1) {
perror("sort");
}
} else {
dup2(pipefd[READ], READ);
dup2(pipefd[WRITE], WRITE);
close(pipefd[READ]);
close(pipefd[WRITE]);
wait(&status);
if(execvp("grep", args) == -1) {
perror("grep");
}
}
}
我正在使用 dup2 将管道的文件描述符复制到标准输入和标准输出,然后关闭未使用的文件描述符。尽管这样做程序从来没有 returns,这让我相信它正在尝试从一个没有被写入的文件描述符中读取,从而阻止了进程。我完全迷失了这一点,可以使用一些提示。 sortfile的内容是a b f s g
.
父项和子项的 dup2
调用是相同的。那是不对的。子(排序)需要写入父(grep)从中读取的管道。
我正在尝试使用 execvp
到 运行 grep
。这个程序背后的想法是 fork 一个子进程,使子进程 sort
成为一个名为 sortfile 的文件,然后父进程将在排序后的输出上使用 grep
。下面是我的代码。
#include <stdio.h>
#include <unistd.h>
#include <sys/types.h>
#include <sys/wait.h>
#define READ 0
#define WRITE 1
int main(int argc, char* argv) {
pid_t cpid;
int status;
int pipefd[2];
pipe(pipefd);
char* args[] = {"grep", "f", NULL};
cpid = fork();
if(cpid == 0) {
dup2(pipefd[READ], READ);
dup2(pipefd[WRITE], WRITE);
close(pipefd[READ]);
close(pipefd[WRITE]);
if(execlp("sort", "sort", "sortfile", NULL) == -1) {
perror("sort");
}
} else {
dup2(pipefd[READ], READ);
dup2(pipefd[WRITE], WRITE);
close(pipefd[READ]);
close(pipefd[WRITE]);
wait(&status);
if(execvp("grep", args) == -1) {
perror("grep");
}
}
}
我正在使用 dup2 将管道的文件描述符复制到标准输入和标准输出,然后关闭未使用的文件描述符。尽管这样做程序从来没有 returns,这让我相信它正在尝试从一个没有被写入的文件描述符中读取,从而阻止了进程。我完全迷失了这一点,可以使用一些提示。 sortfile的内容是a b f s g
.
父项和子项的 dup2
调用是相同的。那是不对的。子(排序)需要写入父(grep)从中读取的管道。