C# 实现进程间通信的几种方式(完善)

目录

引言

一、基本概念

二、常见的IPC方法

1. 管道(Pipes)

2. 共享内存(Shared Memory)

3. 消息队列(Message Queues)

4. 套接字(Sockets)

5. 信号量(Semaphores)

6. 文件映射(File Mapping)

7. 远程过程调用(RPC)

三、总结


引言

进程间通信(IPC)是指在操作系统中,不同进程之间交换数据和信息的机制。在C#中,IPC可以通过多种方式实现,包括文件共享、命名管道、套接字、消息队列、远程过程调用(RPC)等。每种方法都有其特定的应用场景和优缺点。

一、基本概念

  1. 进程(Process)

    • 进程是操作系统中运行的程序实例。每个进程都有自己的内存空间、代码、数据和系统资源。进程之间相互独立,默认情况下无法直接访问彼此的内存空间。
  2. 进程间通信(IPC)

    • IPC允许进程共享资源、同步操作、传递消息等,是进程协作的基础。

二、常见的IPC方法

1. 管道(Pipes)

管道是一种半双工的通信机制,可以在同一台机器上的两个进程之间传输数据。包括匿名管道和命名管道。

应用场景: 常用于本地进程间的简单通信。

技术关键点: 数据流传输,适合父子进程。

// 服务器端
using (var serverPipe = new NamedPipeServerStream("testpipe", PipeDirection.InOut))
{
    Console.WriteLine("Waiting for client connection...");
    serverPipe.WaitForConnection(); // 等待客户端连接
    using (var reader = new StreamReader(serverPipe))
    using (var writer = new StreamWriter(serverPipe))
    {
        writer.WriteLine("Hello from server"); // 向客户端发送消息
        writer.Flush();
        string message = reader.ReadLine(); // 读取客户端发送的消息
        Console.WriteLine("Received from client: " + message);
    }
}

// 客户端
using (var clientPipe = new NamedPipeClientStream(".", "testpipe", PipeDirection.InOut))
{
    Console.WriteLine("Connecting to server...");
    clientPipe.Connect(); // 连接到服务器
    using (var reader = new StreamReader(clientPipe))
    using (var writer = new StreamWriter(clientPipe))
    {
        string message = reader.ReadLine(); // 读取服务器发送的消息
        Console.WriteLine("Received from server: " + message);
        writer.WriteLine("Hello from client"); // 向服务器发送消息
        writer.Flush();
    }
}

服务器端代码解释:

  • 创建一个命名管道服务器。
  • 等待客户端连接。
  • 使用StreamReaderStreamWriter进行数据读写。

客户端代码解释:

  • 创建一个命名管道客户端。
  • 连接到服务器。
  • 使用StreamReaderStreamWriter进行数据读写。

 

2. 共享内存(Shared Memory)

共享内存允许两个或多个进程访问同一块内存区域,是最快的IPC形式。

应用场景: 高性能要求的场景。

技术关键点: 内存同步,数据一致性。

// 使用MemoryMappedFile创建共享内存
using (var mmf = MemoryMappedFile.CreateNew("MyMap", 1024))
{
    using (var accessor = mmf.CreateViewAccessor())
    {
        // 准备数据
        byte[] data = new byte[1024];
        // 写入数据到共享内存
        accessor.WriteArray(0, data, 0, data.Length);
        // 读取数据
        accessor.ReadArray(0, data, 0, data.Length);
    }
}

代码解释:

  • 创建或打开一个共享内存对象。
  • 使用视图访问器来读写内存数据。
3. 消息队列(Message Queues)

消息队列允许进程通过发送和接收消息来通信,支持异步操作。

应用场景: 分布式系统,异步消息传递。

技术关键点: 消息持久化,异步处理。

// 发送消息
using (var queue = new MessageQueue(@".\Private$\MyQueue"))
{
    queue.Send("Hello, World!"); // 发送一条消息到队列
}

// 接收消息
using (var queue = new MessageQueue(@".\Private$\MyQueue"))
{
    queue.Formatter = new XmlMessageFormatter(new[] { typeof(string) });
    var message = queue.Receive(); // 接收消息
    string content = (string)message.Body; // 读取消息内容
    Console.WriteLine(content);
}

代码解释:

  • 创建或打开一个消息队列。
  • 使用System.Messaging库发送和接收消息。

 

4. 套接字(Sockets)

套接字支持网络通信,可用于本地或远程进程间通信。

应用场景: 网络应用,实时通信。

技术关键点: 协议选择(TCP/UDP),数据传输稳定性。

// 服务器端
var listener = new TcpListener(IPAddress.Any, 5000);
listener.Start(); // 启动监听
Console.WriteLine("Waiting for connection...");
var client = listener.AcceptTcpClient(); // 接受客户端连接
using (var stream = client.GetStream())
using (var reader = new StreamReader(stream))
using (var writer = new StreamWriter(stream))
{
    writer.WriteLine("Hello from server"); // 发送消息给客户端
    writer.Flush();
    string message = reader.ReadLine(); // 读取客户端消息
    Console.WriteLine("Received from client: " + message);
}

// 客户端
var client = new TcpClient();
client.Connect("localhost", 5000); // 连接到服务器
using (var stream = client.GetStream())
using (var reader = new StreamReader(stream))
using (var writer = new StreamWriter(stream))
{
    string message = reader.ReadLine(); // 读取服务器消息
    Console.WriteLine("Received from server: " + message);
    writer.WriteLine("Hello from client"); // 发送消息给服务器
    writer.Flush();
}

服务器端代码解释:

  • 创建一个TCP监听器。
  • 等待客户端连接。
  • 使用StreamReaderStreamWriter进行数据读写。

客户端代码解释:

  • 创建一个TCP客户端。
  • 连接到服务器。
  • 使用StreamReaderStreamWriter进行数据读写。

 

5. 信号量(Semaphores)

用于同步多个进程对共享资源的访问。

应用场景: 并发控制,资源管理。

技术关键点: 并发访问控制,资源锁定。

// 使用Semaphore进行进程同步

Semaphore semaphore = new Semaphore(initialCount: 1, maximumCount: 1, name: "MySemaphore");

semaphore.WaitOne(); // 请求访问共享资源

// 执行临界区中的代码

semaphore.Release(); // 释放共享资源

代码解释:

  • 创建或打开一个信号量对象。
  • 控制对共享资源的访问。

 

6. 文件映射(File Mapping)

允许进程将文件内容映射到内存中,实现数据共享。

应用场景: 文件共享,数据缓存。

技术关键点: 文件访问同步,内存映射效率。

// 使用FileStream和MemoryMappedFile进行文件映射
using (FileStream fs = new FileStream("data.txt", FileMode.OpenOrCreate, FileAccess.ReadWrite))
{
    using (MemoryMappedFile mmf = MemoryMappedFile.CreateFromFile(fs, "MyMap", fs.Length, MemoryMappedFileAccess.ReadWrite, null, HandleInheritability.None, false))
    {
        using (var accessor = mmf.CreateViewAccessor())
        {
            accessor.Write(0, (byte)42); // 写入数据到映射文件
            Console.WriteLine(accessor.ReadByte(0)); // 读取数据
        }
    }
}

代码解释:

  • 使用FileStream打开一个文件。
  • 将文件内容映射到内存。
  • 使用视图访问器来读写内存数据。

 

7. 远程过程调用(RPC)

允许进程调用远程函数,提供分布式计算支持。

应用场景: 分布式系统,服务调用。

技术关键点: 调用序列化,网络通信可靠性。

// 定义服务契约
[ServiceContract]
public interface IMyService
{
    [OperationContract]
    string SayHello(string name);
}

// 实现服务
public class MyService : IMyService
{
    public string SayHello(string name)
    {
        return $"Hello, {name}!";
    }
}

// 配置和托管服务
var host = new ServiceHost(typeof(MyService), new Uri("http://localhost:8000/MyService"));
host.AddServiceEndpoint(typeof(IMyService), new BasicHttpBinding(), "");
host.Open();
Console.WriteLine("Service is running... Press [Enter] to exit.");
Console.ReadLine();
host.Close();

// 客户端调用
var factory = new ChannelFactory<IMyService>(new BasicHttpBinding(), new EndpointAddress("http://localhost:8000/MyService"));
var proxy = factory.CreateChannel();
string result = proxy.SayHello("World"); // 调用远程服务
Console.WriteLine(result);
((IClientChannel)proxy).Close();
factory.Close();

服务器端实现步骤:

  • 定义服务契约。
  • 实现服务契约。
  • 使用WCF托管服务。

客户端实现步骤:

  • 创建服务契约的通道工厂。
  • 调用远程方法。

 

三、总结

进程间通信是C#中实现不同进程之间数据交换和信息传递的重要机制。常见的IPC方法包括文件共享、命名管道、套接字、消息队列和远程过程调用。每种方法都有其特定的应用场景和优缺点。

  • 文件共享: 简单易用,但性能较低,需要处理文件锁定和同步问题。
  • 命名管道: 支持双向通信,适用于局域网内的进程间通信。
  • 套接字: 支持跨网络通信,适用于TCP/IP或UDP协议的通信。
  • 消息队列: 支持异步通信和解耦合,适用于分布式系统。
  • 远程过程调用: 允许进程调用远程计算机上的函数或方法,适用于分布式应用。

通过合理选择和使用这些IPC方法,开发者可以实现高效、稳定且可扩展的进程间通信。了解每种方法的原理和应用场景,可以帮助开发者更好地设计和实现复杂的分布式系统。

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:/a/901641.html

如若内容造成侵权/违法违规/事实不符,请联系我们进行投诉反馈qq邮箱809451989@qq.com,一经查实,立即删除!

相关文章

最新版本jdbcutils集成log4j做详细sql日志、自动释放连接...等

maven坐标 <!-- MySQL 8 --><dependency><groupId>com.mysql</groupId><artifactId>mysql-connector-j</artifactId><version>8.0.33</version></dependency><!-- Druid连接池 --><dependency><groupId&…

sass软件登录设定——未来之窗行业应用跨平台架构

一、saas软件开发中登录设计 以为大公司为参考思迅在登录时候需要录入商户号 二、独立商户商户好处 1.每个店铺的账户是独立的&#xff0c;保护商户职员账户信息的相对安全。 2.不同店铺可以试用相同用户名

qt QMediaPlaylist

QMediaPlaylist 是 Qt Multimedia 模块中的一个类&#xff0c;用于管理媒体文件的播放列表。它提供了一种方便的方式来组织和控制多媒体内容的播放&#xff0c;如音频和视频文件。 主要方法 QMediaPlaylist(00bject *parent nullptr):构造一个新的媒体播放列表对象。void add…

低代码平台如何通过AI赋能,实现更智能的业务自动化?

引言 随着数字化转型的加速推进&#xff0c;企业在日常运营中面临的业务复杂性与日俱增。如何快速响应市场需求&#xff0c;优化流程&#xff0c;并降低开发成本&#xff0c;成为各行业共同关注的核心问题。低代码平台作为一种能够快速构建应用程序的工具&#xff0c;因其可视化…

ArcGIS003:ArcMap常用操作0-50例动图演示

摘要&#xff1a;本文以动图形式介绍了ArcMap软件的基本操作&#xff0c;包括快捷方式创建、管理许可服务、操作界面元素&#xff08;如内容列表、目录树、搜索窗口、工具箱、Python窗口、模型构建器窗口等&#xff09;的打开与关闭、位置调整及合并&#xff0c;设置默认工作目…

【JavaEE初阶】网络原理-TCP连接管理之“三次握手和四次挥手”

前言 &#x1f31f;&#x1f31f;本期讲解关于TCP协议的重要的机制“连接的建立和断开”~~~ &#x1f308;感兴趣的小伙伴看一看小编主页&#xff1a;GGBondlctrl-CSDN博客 &#x1f525; 你的点赞就是小编不断更新的最大动力 &…

Linux 部署 mysql

Linux&#xff08;四&#xff09;- Ubuntu安装Mysql_mysql-community-server-core depends on libaio1 (>-CSDN博客 #创建用户 打开终端。 登录到MySQL服务器&#xff1a; mysql -u root -p 创建新用户。替换new_user为您想要的用户名&#xff0c;password为新用户的密码&am…

python异常监测-ARIMA(自回归积分滑动平均模型)

系列文章目录 Python异常检测- Isolation Forest&#xff08;孤立森林&#xff09; python异常检测 - 随机离群选择Stochastic Outlier Selection (SOS) python异常检测-局部异常因子&#xff08;LOF&#xff09;算法 Python异常检测- DBSCAN Python异常检测- 单类支持向量机(…

python之数据结构与算法(数据结构篇)-- 元组

一、元组的概念 其实&#xff0c;所谓的“元组”就是一组不能改变的特殊数组(一般情况下)&#xff0c;这里我们去创建一个“小羊元组”&#xff0c;大家就能更加明白其中的意思了。 二、元组实现思路 1.我们去定义一个“羊村小羊”的元组 # 创建一个"羊村小羊"的元…

SystemC学习(2)— APB_SRAM的建模与测试

SystemC学习&#xff08;2&#xff09;— APB_SRAM的建模与测试 一、前言 二、APB_SRAM建模 编写APB_SRAM模型文件apb_sram.h文件如下所示&#xff1a; #ifndef __APB_SRAM_H #define __APB_SRAM_H#include "systemc.h"const int ADDR_SIZE 32; const int DATA_…

【专题】计算机网络之数据链路层

数据链路层的地位&#xff1a;网络中的主机、路由器等都必须实现数据链路层。 数据链路层信道类型&#xff1a; 点对点信道。 使用一对一的点对点通信方式。 广播信道。 使用一对多的广播通信方式。 必须使用专用的共享信道协议来协调这些主机的数据发送。 1. 使用点对点信道…

三次握手与四次挥手

1.三次握手 1.1状态机 客户端 SYN_SENT&#xff1a;客户端发送SYN报文段请求建立连接 ESTABLISHED&#xff1a;在收到服务端发来的SYN请求报文以及确认报文后就建立客户端到服务端的连接 服务端 LISTEN&#xff1a;一开始时LISTEN状态&#xff0c;等待客户端的SYN请求 SY…

群晖系统基本命令

切换超级管理员 sudo -i 查询系统 运行的所有服务 synoservicecfg --list 启动服务命令(该命令需要使用超级管理员) #老版本群晖使用synoservice命令 synoservice --start 服务名称#新版本群晖使用systemctl命令 systemctl start 服务名称 synoservice所管理的服务配置文…

MySql数据库中数据类型

本篇将介绍在 MySql 中的所有数据类型&#xff0c;其中主要分为四类&#xff1a;数值类型、文本和二进制类型、时间日期、String 类型。如下&#xff08;图片来源&#xff1a;MySQL数据库&#xff09;&#xff1a; 目录如下&#xff1a; 目录 数值类型 1. 整数类型 2. …

【网站项目】SpringBoot397学校财务管理系统

&#x1f64a;作者简介&#xff1a;多年一线开发工作经验&#xff0c;原创团队&#xff0c;分享技术代码帮助学生学习&#xff0c;独立完成自己的网站项目。 代码可以查看文章末尾⬇️联系方式获取&#xff0c;记得注明来意哦~&#x1f339;赠送计算机毕业设计600个选题excel文…

【论文阅读】SRGAN

学习资料 论文题目&#xff1a;基于生成对抗网络的照片级单幅图像超分辨率&#xff08;Photo-Realistic Single Image Super-Resolution Using a Generative Adversarial Network&#xff09;论文地址&#xff1a;https://arxiv.org/abs/1609.04802 代码&#xff1a;GitHub - x…

【Python爬虫实战】Selenium自动化网页操作入门指南

#1024程序员节&#xff5c;征文# &#x1f308;个人主页&#xff1a;易辰君-CSDN博客 &#x1f525; 系列专栏&#xff1a;https://blog.csdn.net/2401_86688088/category_12797772.html ​ 目录 前言 一、准备工作 &#xff08;一&#xff09;安装 Selenium 库 &#xff0…

SpringBoot项目里怎么简单高效使用Redis?我选择使用Lock4j

文章目录 前言正文1、Lock4j的代码仓库2、pine-manage-common-redis的项目结构3、pine-manage-common-redis 的完整代码3.1 maven依赖&#xff1a;pom.xml3.2 redis连接参数&#xff1a;application.yaml3.3 RedisCache.java3.4 CacheConfig.java3.5 RedissonClientUtil.java3.…

Python | Leetcode Python题解之第509题斐波那契数

题目&#xff1a; 题解&#xff1a; class Solution:def fib(self, n: int) -> int:if n < 2:return nq [[1, 1], [1, 0]]res self.matrix_pow(q, n - 1)return res[0][0]def matrix_pow(self, a: List[List[int]], n: int) -> List[List[int]]:ret [[1, 0], [0, …

Redisson(三)应用场景及demo

一、基本的存储与查询 分布式环境下&#xff0c;为了方便多个进程之间的数据共享&#xff0c;可以使用RedissonClient的分布式集合类型&#xff0c;如List、Set、SortedSet等。 1、demo <parent><groupId>org.springframework.boot</groupId><artifact…