c语言+pipe实现父子进程通信(双向通信+发送多条信息)

本文主要是介绍c语言+pipe实现父子进程通信(双向通信+发送多条信息),希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

chatgpt写的,我调了一下,觉得挺好,发个博客记录一下
测试环境是ubuntu
感觉关键就是write的时候要sleep,然后写的时候要while读。总觉得怪怪的,干脆一次读写完算了。

#include <stdio.h>
#include <stdlib.h>
#include <unistd.h>
#include <string.h>
#include <sys/types.h>
#include <sys/wait.h>
#include <signal.h>#define BUFFER_SIZE 256int main() {int pipe_parent_child[2];  // 父进程到子进程的管道int pipe_child_parent[2];  // 子进程到父进程的管道pid_t pid;char buffer[BUFFER_SIZE];// 创建父子进程间的管道if (pipe(pipe_parent_child) == -1 || pipe(pipe_child_parent) == -1) {perror("Pipe creation failed");exit(EXIT_FAILURE);}// 创建子进程pid = fork();if (pid == -1) {perror("Fork failed");exit(EXIT_FAILURE);}if (pid > 0) { // Parent processclose(pipe_parent_child[0]); // 父进程关闭从父进程到子进程的读端close(pipe_child_parent[1]); // 父进程关闭从子进程到父进程的写端// 父进程向子进程发送消息const char* messages_to_child[] = {"Hello, child!", "How are you?", "Do you want to play?"};for (int i = 0; i < sizeof(messages_to_child) / sizeof(messages_to_child[0]); ++i) {write(pipe_parent_child[1], messages_to_child[i], strlen(messages_to_child[i]) + 1);printf("Parent sent: %s\n", messages_to_child[i]);sleep(1); // 延迟一秒,模拟发送多条消息的间隔}close(pipe_parent_child[1]); // 关闭父进程到子进程的写端,表示发送完毕// 父进程从子进程接收消息while (read(pipe_child_parent[0], buffer, BUFFER_SIZE) > 0) {printf("Parent received: %s\n", buffer);}close(pipe_child_parent[0]); // 关闭从子进程到父进程的读端} else { // Child processclose(pipe_parent_child[1]); // 子进程关闭从父进程到子进程的写端close(pipe_child_parent[0]); // 子进程关闭从子进程到父进程的读端// 子进程从父进程接收消息while (read(pipe_parent_child[0], buffer, BUFFER_SIZE) > 0) {printf("Child received: %s\n", buffer);}close(pipe_parent_child[0]); // 关闭从父进程到子进程的读端// 子进程向父进程发送消息const char* messages_to_parent[] = {"Hi, parent!", "I'm fine, thanks.", "Sure!"};for (int i = 0; i < sizeof(messages_to_parent) / sizeof(messages_to_parent[0]); ++i) {write(pipe_child_parent[1], messages_to_parent[i], strlen(messages_to_parent[i]) + 1);printf("Child sent: %s\n", messages_to_parent[i]);sleep(1); // 延迟一秒,模拟发送多条消息的间隔}close(pipe_child_parent[1]); // 关闭从子进程到父进程的写端,表示发送完毕}return 0;
}

这篇关于c语言+pipe实现父子进程通信(双向通信+发送多条信息)的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/851339

相关文章

Oracle查询优化之高效实现仅查询前10条记录的方法与实践

《Oracle查询优化之高效实现仅查询前10条记录的方法与实践》:本文主要介绍Oracle查询优化之高效实现仅查询前10条记录的相关资料,包括使用ROWNUM、ROW_NUMBER()函数、FET... 目录1. 使用 ROWNUM 查询2. 使用 ROW_NUMBER() 函数3. 使用 FETCH FI

Python脚本实现自动删除C盘临时文件夹

《Python脚本实现自动删除C盘临时文件夹》在日常使用电脑的过程中,临时文件夹往往会积累大量的无用数据,占用宝贵的磁盘空间,下面我们就来看看Python如何通过脚本实现自动删除C盘临时文件夹吧... 目录一、准备工作二、python脚本编写三、脚本解析四、运行脚本五、案例演示六、注意事项七、总结在日常使用

Java实现Excel与HTML互转

《Java实现Excel与HTML互转》Excel是一种电子表格格式,而HTM则是一种用于创建网页的标记语言,虽然两者在用途上存在差异,但有时我们需要将数据从一种格式转换为另一种格式,下面我们就来看看... Excel是一种电子表格格式,广泛用于数据处理和分析,而HTM则是一种用于创建网页的标记语言。虽然两

Java中Springboot集成Kafka实现消息发送和接收功能

《Java中Springboot集成Kafka实现消息发送和接收功能》Kafka是一个高吞吐量的分布式发布-订阅消息系统,主要用于处理大规模数据流,它由生产者、消费者、主题、分区和代理等组件构成,Ka... 目录一、Kafka 简介二、Kafka 功能三、POM依赖四、配置文件五、生产者六、消费者一、Kaf

在C#中获取端口号与系统信息的高效实践

《在C#中获取端口号与系统信息的高效实践》在现代软件开发中,尤其是系统管理、运维、监控和性能优化等场景中,了解计算机硬件和网络的状态至关重要,C#作为一种广泛应用的编程语言,提供了丰富的API来帮助开... 目录引言1. 获取端口号信息1.1 获取活动的 TCP 和 UDP 连接说明:应用场景:2. 获取硬

使用Python实现在Word中添加或删除超链接

《使用Python实现在Word中添加或删除超链接》在Word文档中,超链接是一种将文本或图像连接到其他文档、网页或同一文档中不同部分的功能,本文将为大家介绍一下Python如何实现在Word中添加或... 在Word文档中,超链接是一种将文本或图像连接到其他文档、网页或同一文档中不同部分的功能。通过添加超

windos server2022里的DFS配置的实现

《windosserver2022里的DFS配置的实现》DFS是WindowsServer操作系统提供的一种功能,用于在多台服务器上集中管理共享文件夹和文件的分布式存储解决方案,本文就来介绍一下wi... 目录什么是DFS?优势:应用场景:DFS配置步骤什么是DFS?DFS指的是分布式文件系统(Distr

NFS实现多服务器文件的共享的方法步骤

《NFS实现多服务器文件的共享的方法步骤》NFS允许网络中的计算机之间共享资源,客户端可以透明地读写远端NFS服务器上的文件,本文就来介绍一下NFS实现多服务器文件的共享的方法步骤,感兴趣的可以了解一... 目录一、简介二、部署1、准备1、服务端和客户端:安装nfs-utils2、服务端:创建共享目录3、服

SpringBoot使用Apache Tika检测敏感信息

《SpringBoot使用ApacheTika检测敏感信息》ApacheTika是一个功能强大的内容分析工具,它能够从多种文件格式中提取文本、元数据以及其他结构化信息,下面我们来看看如何使用Ap... 目录Tika 主要特性1. 多格式支持2. 自动文件类型检测3. 文本和元数据提取4. 支持 OCR(光学

C#使用yield关键字实现提升迭代性能与效率

《C#使用yield关键字实现提升迭代性能与效率》yield关键字在C#中简化了数据迭代的方式,实现了按需生成数据,自动维护迭代状态,本文主要来聊聊如何使用yield关键字实现提升迭代性能与效率,感兴... 目录前言传统迭代和yield迭代方式对比yield延迟加载按需获取数据yield break显式示迭