在UNIX中,管道是一种进程间通信方式,它通过创建一个在两个进程之间共享的缓冲区来传递数据。可以使用管道在父进程和子进程之间传输数据。
以下是使用管道在UNIX中在两个进程之间传递数据的示例代码:
#include
#include
#include
int main()
{
int fd[2];
pid_t pid;
if (pipe(fd) == -1) {
fprintf(stderr, "Pipe failed");
return 1;
}
pid = fork();
if (pid < 0) {
fprintf(stderr, "Fork failed");
return 1;
}
if (pid > 0) {
char message[100] = "Hello, child process!";
close(fd[0]);
write(fd[1], message, sizeof(message));
close(fd[1]);
} else {
char buffer[100];
close(fd[1]);
read(fd[0], buffer, sizeof(buffer));
printf("Message from parent process: %s\n", buffer);
close(fd[0]);
}
return 0;
}
在这个示例中,我们使用了一个整型数组fd
来创建一个管道。fd[0]
是管道的读取端,fd[1]
是管道的写入端。然后创建了一个子进程,子进程会从父进程读取数据。父进程向管道中写入一条消息,子进程从管道中读取并打印出来。
通过这个例子,我们可以更好地理解管道的工作原理。
下一篇:不理解关系UML的差异