【Linux】进程间通信_3

简介: 【Linux】进程间通信_3

七、进程间通信

1. 进程间通信分类

命名管道

管道应用的一个限制就是只能在具有共同祖先(具有亲缘关系)的进程间通信。如果我们想在不相关的进程之间交换数据,可以使用FIFO文件来做这项工作,它经常被称为命名管道。命名管道是一种特殊类型的文件。

我们只需要使用 mkfifo 命令就可以在当前路径下创建命名管道。

Makefile

.PHONY:all
all:pipe_server pipe_client
pipe_server:PipeServer.cc
  g++ -o $@ $^ -std=c++11
pipe_client:PipeClient.cc
  g++ -o $@ $^ -std=c++11
.PHONY:clean
clean:
  rm -f pipe_server pipe_client

Comm.hpp

#ifndef __COMM_HPP__
#define __COMM_HPP__
#include <iostream>
#include <string>
#include <sys/types.h>
#include <sys/stat.h>
#include <cerrno>
#include <cstring>
#include <unistd.h>
#include <fcntl.h>
using namespace std;
#define Mode 0666
#define Path "fifo"
// 命名管道类
class Fifo
{
public:
    Fifo(const string& path)
    : _path(path)
    {
        umask(0);
        // 创建命名管道
        int n = mkfifo(_path.c_str(), Mode);
        if (n == 0)
        {
            cout << "mkfifo success" << endl;
        }
        else
        {
            cout << "mkfifo failed, error : " << errno << "errstring : " << strerror(errno) << endl;
        }
    }
    ~Fifo()
    {
        // 删除命名管道
        int n = unlink(_path.c_str());
        if (n == 0)
        {
            cout << "remove " << _path << " success" << endl;
        }
        else
        {
            cout << "remove failed, error : " << errno << "errstring : " << strerror(errno) << endl;
        }
    }
private:
    // 文件路径 + 文件名
    string _path;
};
#endif

pipe_server(服务端接收消息):

#include "Comm.hpp"
#include <unistd.h>
int main()
{
    // 创建命名管道
    Fifo fifo(Path);
    // 打开命名管道文件
    int rfd = open(Path, O_RDONLY);
    if (rfd < 0)
    {
        cerr << "open failed, errno: " << errno << " , errnostring: " << strerror(errno) << endl;
        return 1;
    }
    char buffer[1024];
    // 循环读取管道数据
    while (true)
    {
        ssize_t n = read(rfd, buffer, sizeof(buffer) - 1);
        if (n > 0)
        {
            buffer[n] = 0;
            cout << "client says: " << buffer << endl;
        }
        else if (n == 0)
        {
            cout << "client quie, me too" << endl;
            break;
        }
        else
        {
            cerr << "read failed, errno: " << errno << " , errnostring: " << strerror(errno) << endl;
            break;
        }
    }
    // 关闭命名管道文件
    close(rfd);
    return 0;
}

pipe_client(客户端输入消息):

#include "Comm.hpp"
int main()
{
    // 以写的方式打开命名管道文件
    int rfd = open(Path, O_WRONLY);
    if (rfd < 0)
    {
        cerr << "open failed, errno: " << errno << " , errnostring: " << strerror(errno) << endl;
        return 1;
    }
    string inbuffer;
    // 循环读取用户输入并写入管道
    while (true)
    {
        cout << "Please Enter Your Message# ";
        getline(cin, inbuffer);
        if (inbuffer == "quit") break;
        ssize_t n = write(rfd, inbuffer.c_str(), inbuffer.size());
        if (n < 0)
        {
            cerr << "write failed, errno: " << errno << " , errnostring: " << strerror(errno) << endl;
        }
    }
    // 关闭管道文件
    close(rfd);
    return 0;
}

结果:


未完待续

目录
相关文章
|
22天前
|
网络协议 Linux
Linux查看端口监听情况,以及Linux查看某个端口对应的进程号和程序
Linux查看端口监听情况,以及Linux查看某个端口对应的进程号和程序
99 2
|
22天前
|
Linux Python
linux上根据运行程序的进程号,查看程序所在的绝对路径。linux查看进程启动的时间
linux上根据运行程序的进程号,查看程序所在的绝对路径。linux查看进程启动的时间
39 2
|
25天前
|
消息中间件 Linux 开发者
Linux进程间通信秘籍:管道、消息队列、信号量,一文让你彻底解锁!
【8月更文挑战第25天】本文概述了Linux系统中常用的五种进程间通信(IPC)模式:管道、消息队列、信号量、共享内存与套接字。通过示例代码展示了每种模式的应用场景。了解这些IPC机制及其特点有助于开发者根据具体需求选择合适的通信方式,促进多进程间的高效协作。
50 3
|
23天前
|
消息中间件 Linux
Linux进程间通信
Linux进程间通信
32 1
|
24天前
|
C语言
Linux0.11 系统调用进程创建与执行(九)(下)
Linux0.11 系统调用进程创建与执行(九)
20 1
|
24天前
|
存储 Linux 索引
Linux0.11 系统调用进程创建与执行(九)(上)
Linux0.11 系统调用进程创建与执行(九)
35 1
|
6天前
|
存储 监控 安全
探究Linux操作系统的进程管理机制及其优化策略
本文旨在深入探讨Linux操作系统中的进程管理机制,包括进程调度、内存管理以及I/O管理等核心内容。通过对这些关键组件的分析,我们将揭示它们如何共同工作以提供稳定、高效的计算环境,并讨论可能的优化策略。
13 0
|
28天前
|
消息中间件 Linux
在Linux中,进程间通信方式有哪些?
在Linux中,进程间通信方式有哪些?
|
18天前
|
Unix Linux
linux中在进程之间传递文件描述符的实现方式
linux中在进程之间传递文件描述符的实现方式
|
19天前
|
开发者 API Windows
从怀旧到革新:看WinForms如何在保持向后兼容性的前提下,借助.NET新平台的力量实现自我进化与应用现代化,让经典桌面应用焕发第二春——我们的WinForms应用转型之路深度剖析
【8月更文挑战第31天】在Windows桌面应用开发中,Windows Forms(WinForms)依然是许多开发者的首选。尽管.NET Framework已演进至.NET 5 及更高版本,WinForms 仍作为核心组件保留,支持现有代码库的同时引入新特性。开发者可将项目迁移至.NET Core,享受性能提升和跨平台能力。迁移时需注意API变更,确保应用平稳过渡。通过自定义样式或第三方控件库,还可增强视觉效果。结合.NET新功能,WinForms 应用不仅能延续既有投资,还能焕发新生。 示例代码展示了如何在.NET Core中创建包含按钮和标签的基本窗口,实现简单的用户交互。
43 0