c++ linux通过实现独立进程之间的通信和传递字符串 demo

简介: 的进程间通信机制,适用于父子进程之间的数据传输。希望本文能帮助您更好地理解和应用Linux管道,提升开发效率。在实际开发中,除了管道,还可以根据具体需求选择消息队列、共享内存、套接字等其他进程间通信方

通过管道实现C++ Linux独立进程之间的通信和字符串传递

在Linux环境下,独立进程之间的通信(IPC)可以通过多种方式实现,包括管道、消息队列、共享内存和套接字。本文将详细介绍如何使用管道(pipe)在C++中实现独立进程之间的通信,并传递字符串。

一、管道简介

管道是Linux系统提供的一种进程间通信机制。管道本质上是内核缓冲区,可以在进程之间传递数据。管道分为无名管道和有名管道(FIFO)。本文将使用无名管道实现进程间的字符串传递。

二、实现步骤

2.1 创建管道

使用 pipe()系统调用创建一个无名管道。pipe()会创建一个包含两个文件描述符的数组:pipefd[0]用于读取,pipefd[1]用于写入。

2.2 创建子进程

使用 fork()系统调用创建一个子进程。在父进程中写入数据到管道中,在子进程中读取数据并打印出来。

2.3 代码示例

以下是一个完整的C++代码示例,演示如何通过管道在父子进程之间传递字符串:

#include <iostream>
#include <unistd.h>
#include <cstring>
#include <sys/wait.h>

int main() {
    int pipefd[2];
    pid_t pid;
    char buffer[128];
    const char* message = "Hello from parent process!";

    // 创建管道
    if (pipe(pipefd) == -1) {
        perror("pipe");
        return 1;
    }

    // 创建子进程
    pid = fork();
    if (pid == -1) {
        perror("fork");
        return 1;
    }

    if (pid == 0) {
        // 子进程:从管道中读取数据
        close(pipefd[1]); // 关闭写端
        read(pipefd[0], buffer, sizeof(buffer));
        std::cout << "Child process received: " << buffer << std::endl;
        close(pipefd[0]); // 关闭读端
    } else {
        // 父进程:向管道中写入数据
        close(pipefd[0]); // 关闭读端
        write(pipefd[1], message, strlen(message) + 1);
        close(pipefd[1]); // 关闭写端

        // 等待子进程结束
        wait(NULL);
    }

    return 0;
}
​

2.4 代码解释

  1. 创建管道:使用 pipe(pipefd)创建管道,pipefd是一个包含两个文件描述符的数组。

  2. 创建子进程:使用 fork()创建子进程。在父进程中,fork()返回子进程的PID;在子进程中,fork()返回0。

  3. 子进程读取数据

    • 关闭管道的写端(pipefd[1])。
    • 使用 read(pipefd[0], buffer, sizeof(buffer))从管道中读取数据。
    • 打印读取到的数据。
    • 关闭管道的读端(pipefd[0])。
  4. 父进程写入数据

    • 关闭管道的读端(pipefd[0])。
    • 使用 write(pipefd[1], message, strlen(message) + 1)向管道中写入数据。
    • 关闭管道的写端(pipefd[1])。
    • 使用 wait(NULL)等待子进程结束。

三、运行结果

编译并运行上述代码,应该会看到如下输出:

Child process received: Hello from parent process!
​

这表明父进程成功地通过管道将字符串传递给了子进程。

四、总结

通过本文的介绍,我们详细讲解了如何使用管道在C++中实现独立进程之间的通信,并成功地传递字符串。管道是一种简单而高效的进程间通信机制,适用于父子进程之间的数据传输。希望本文能帮助您更好地理解和应用Linux管道,提升开发效率。

在实际开发中,除了管道,还可以根据具体需求选择消息队列、共享内存、套接字等其他进程间通信方

目录
相关文章
|
8月前
|
存储 Shell Linux
八、Linux Shell 脚本:变量与字符串
Shell脚本里的变量就像一个个贴着标签的“箱子”。装东西(赋值)时,=两边千万不能有空格。用单引号''装进去的东西会原封不动,用双引号""则会让里面的$变量先“变身”再装箱。默认箱子只能在当前“房间”(Shell进程)用,想让隔壁房间(子进程)也能看到,就得给箱子盖个export的“出口”戳。此外,Shell还自带了$?(上条命令的成绩单)和$1(别人递进来的第一个包裹)等许多特殊箱子,非常有用。
795 2
|
Web App开发 Linux 程序员
获取和理解Linux进程以及其PID的基础知识。
总的来说,理解Linux进程及其PID需要我们明白,进程就如同汽车,负责执行任务,而PID则是独特的车牌号,为我们提供了管理的便利。知道这个,我们就可以更好地理解和操作Linux系统,甚至通过对进程的有效管理,让系统运行得更加顺畅。
366 16
|
11月前
|
监控 Shell Linux
Linux进程控制(详细讲解)
进程等待是系统通过调用特定的接口(如waitwaitpid)来实现的。来进行对子进程状态检测与回收的功能。
271 0
|
11月前
|
存储 负载均衡 算法
Linux2.6内核进程调度队列
本篇文章是Linux进程系列中的最后一篇文章,本来是想放在上一篇文章的结尾的,但是想了想还是单独写一篇文章吧,虽然说这部分内容是比较难的,所有一般来说是简单的提及带过的,但是为了让大家对进程有更深的理解与认识,还是看了一些别人的文章,然后学习了学习,然后对此做了总结,尽可能详细的介绍明白。最后推荐一篇文章Linux的进程优先级 NI 和 PR - 简书。
336 0
|
11月前
|
存储 Linux Shell
Linux进程概念-详细版(二)
在Linux进程概念-详细版(一)中我们解释了什么是进程,以及进程的各种状态,已经对进程有了一定的认识,那么这篇文章将会继续补全上篇文章剩余没有说到的,进程优先级,环境变量,程序地址空间,进程地址空间,以及调度队列。
219 0
|
11月前
|
Linux 调度 C语言
Linux进程概念-详细版(一)
子进程与父进程代码共享,其子进程直接用父进程的代码,其自己本身无代码,所以子进程无法改动代码,平时所说的修改是修改的数据。为什么要创建子进程:为了让其父子进程执行不同的代码块。子进程的数据相对于父进程是会进行写时拷贝(COW)。
277 0
|
Linux 数据库 Perl
【YashanDB 知识库】如何避免 yasdb 进程被 Linux OOM Killer 杀掉
本文来自YashanDB官网,探讨Linux系统中OOM Killer对数据库服务器的影响及解决方法。当内存接近耗尽时,OOM Killer会杀死占用最多内存的进程,这可能导致数据库主进程被误杀。为避免此问题,可采取两种方法:一是在OS层面关闭OOM Killer,通过修改`/etc/sysctl.conf`文件并重启生效;二是豁免数据库进程,由数据库实例用户借助`sudo`权限调整`oom_score_adj`值。这些措施有助于保护数据库进程免受系统内存管理机制的影响。
|
Linux Shell
Linux 进程前台后台切换与作业控制
进程前台/后台切换及作业控制简介: 在 Shell 中,启动的程序默认为前台进程,会占用终端直到执行完毕。例如,执行 `./shella.sh` 时,终端会被占用。为避免不便,可将命令放到后台运行,如 `./shella.sh &`,此时终端命令行立即返回,可继续输入其他命令。 常用作业控制命令: - `fg %1`:将后台作业切换到前台。 - `Ctrl + Z`:暂停前台作业并放到后台。 - `bg %1`:让暂停的后台作业继续执行。 - `kill %1`:终止后台作业。 优先级调整:
1448 5
|
运维 关系型数据库 MySQL
掌握taskset:优化你的Linux进程,提升系统性能
在多核处理器成为现代计算标准的今天,运维人员和性能调优人员面临着如何有效利用这些处理能力的挑战。优化进程运行的位置不仅可以提高性能,还能更好地管理和分配系统资源。 其中,taskset命令是一个强大的工具,它允许管理员将进程绑定到特定的CPU核心,减少上下文切换的开销,从而提升整体效率。
掌握taskset:优化你的Linux进程,提升系统性能
|
弹性计算 Linux 区块链
Linux系统CPU异常占用(minerd 、tplink等挖矿进程)
Linux系统CPU异常占用(minerd 、tplink等挖矿进程)
734 4
Linux系统CPU异常占用(minerd 、tplink等挖矿进程)