当前位置: 首页 > news >正文

.net/C#进程间通信技术方案总结

C# 应用进程间通信(IPC)技术方案

进程间通信(Inter-Process Communication, IPC)是不同进程之间交换数据和消息的机制。以下是C#中常用的IPC技术方案:

1. 命名管道(Named Pipes)

适用于本地机器上的进程通信,支持双向通信。

​服务端示例​​:

 

csharp

using System.IO.Pipes;var server = new NamedPipeServerStream("MyPipe", PipeDirection.InOut);
server.WaitForConnection();using (StreamReader reader = new StreamReader(server))
using (StreamWriter writer = new StreamWriter(server))
{string message = reader.ReadLine();Console.WriteLine($"Received: {message}");writer.WriteLine("Hello from server!");writer.Flush();
}

​客户端示例​​:

 

csharp

using System.IO.Pipes;var client = new NamedPipeClientStream(".", "MyPipe", PipeDirection.InOut);
client.Connect();using (StreamReader reader = new StreamReader(client))
using (StreamWriter writer = new StreamWriter(client))
{writer.WriteLine("Hello from client!");writer.Flush();string response = reader.ReadLine();Console.WriteLine($"Server response: {response}");
}

2. 内存映射文件(Memory-Mapped Files)

允许不同进程通过共享内存进行通信。

​写入进程​​:

 

csharp

using System.IO.MemoryMappedFiles;using (var mmf = MemoryMappedFile.CreateOrOpen("MySharedMemory", 1024))
using (var accessor = mmf.CreateViewAccessor())
{byte[] message = Encoding.UTF8.GetBytes("Hello from Process 1!");accessor.WriteArray(0, message, 0, message.Length);
}

​读取进程​​:

 

csharp

using (var mmf = MemoryMappedFile.OpenExisting("MySharedMemory"))
using (var accessor = mmf.CreateViewAccessor())
{byte[] buffer = new byte[1024];accessor.ReadArray(0, buffer, 0, buffer.Length);string message = Encoding.UTF8.GetString(buffer).TrimEnd('\0');Console.WriteLine($"Received: {message}");
}

3. WCF (Windows Communication Foundation)

.NET框架提供的强大通信框架,支持多种协议。

​服务端​​:

 

csharp

using System.ServiceModel;[ServiceContract]
public interface IMyService
{[OperationContract]string GetMessage();
}public class MyService : IMyService
{public string GetMessage() => "Hello from WCF service!";
}var host = new ServiceHost(typeof(MyService), new Uri("net.pipe://localhost"));
host.AddServiceEndpoint(typeof(IMyService), new NetNamedPipeBinding(), "MyService");
host.Open();

​客户端​​:

 

csharp

var factory = new ChannelFactory<IMyService>(new NetNamedPipeBinding(),new EndpointAddress("net.pipe://localhost/MyService"));IMyService proxy = factory.CreateChannel();
string message = proxy.GetMessage();
Console.WriteLine($"Service response: {message}");

4. 套接字(Sockets)

适用于网络通信,也可用于本地进程间通信。

​TCP服务端​​:

 

csharp

var listener = new TcpListener(IPAddress.Loopback, 12345);
listener.Start();var client = listener.AcceptTcpClient();
using (var stream = client.GetStream())
using (var reader = new StreamReader(stream))
using (var writer = new StreamWriter(stream))
{string request = reader.ReadLine();writer.WriteLine($"Echo: {request}");writer.Flush();
}

​TCP客户端​​:

 

csharp

var client = new TcpClient("localhost", 12345);
using (var stream = client.GetStream())
using (var reader = new StreamReader(stream))
using (var writer = new StreamWriter(stream))
{writer.WriteLine("Hello from client!");writer.Flush();string response = reader.ReadLine();Console.WriteLine(response);
}

5. 消息队列(MSMQ)

适用于异步、可靠的进程间通信。

​发送消息​​:

 

csharp

using System.Messaging;if (!MessageQueue.Exists(@".\Private$\MyQueue"))MessageQueue.Create(@".\Private$\MyQueue");var queue = new MessageQueue(@".\Private$\MyQueue");
queue.Send("Hello from sender process!", "Test Message");

​接收消息​​:

 

csharp

var queue = new MessageQueue(@".\Private$\MyQueue");
queue.Formatter = new XmlMessageFormatter(new[] { typeof(string) });Message message = queue.Receive();
Console.WriteLine($"Received: {message.Body}");

6. 文件监视(File System Watcher)

通过共享文件和文件系统事件进行通信。

​写入进程​​:

 

csharp

File.WriteAllText("shared.txt", "Hello from Process 1!");

​监视进程​​:

 

csharp

var watcher = new FileSystemWatcher
{Path = Directory.GetCurrentDirectory(),Filter = "shared.txt",NotifyFilter = NotifyFilters.LastWrite
};watcher.Changed += (s, e) => 
{string content = File.ReadAllText(e.FullPath);Console.WriteLine($"File changed: {content}");
};watcher.EnableRaisingEvents = true;

7. COM/DCOM

适用于与遗留系统或非.NET应用程序通信。

​COM服务器示例​​:

 

csharp

[ComVisible(true)]
[Guid("...")]
[ClassInterface(ClassInterfaceType.AutoDual)]
public class MyComServer
{public string GetMessage() => "Hello from COM server!";
}

​COM客户端​​:

 

csharp

Type comType = Type.GetTypeFromProgID("MyComServer");
dynamic comObject = Activator.CreateInstance(comType);
string message = comObject.GetMessage();

选择建议

  1. ​高性能需求​​:内存映射文件或命名管道
  2. ​跨机器通信​​:WCF或套接字
  3. ​可靠异步通信​​:MSMQ
  4. ​简单临时通信​​:文件监视
  5. ​与旧系统集成​​:COM/DCOM

每种方案都有其适用场景,应根据具体需求选择最合适的IPC技术。

相关文章:

  • 机器学习与深度学习的区别与联系:多角度详细分析
  • Linux基础(关于进程相关命令)
  • CSS opacity
  • 计算人声录音后电平的大小(dB SPL->dBFS)
  • 访问网站提示“不安全”“有风险”怎么办?
  • 3D桌面可视化开发平台HOOPS Native Platform,如何实现3D系统快速开发与部署?
  • 【网安播报】Meta 推出 LlamaFirewall开源框架以阻止 AI 越狱、注入和不安全代码
  • 【python】 python拆包
  • buck和boost总结
  • web 自动化之 selenium 元素四大操作三大切换等待
  • Oracle非归档模式遇到文件损坏怎么办?
  • AI NeRF:Meta实现手机端实时毛发渲染,开启移动AR/VR新纪元——从实验室到口袋:NeRF技术的轻量化革命
  • Android Handler 机制面试总结
  • 更新 / 安装 Nvidia Driver 驱动 - Ubuntu - 2
  • Shiro(八):JWT介绍
  • BP神经网络
  • c++:双向链表容器(std::list)
  • 【CTFSHOW_Web入门】命令执行
  • Unity按钮事件冒泡
  • 制作一款打飞机游戏42:敌人大脑
  • 名帅大挪移提前开启,意属皇马的阿隆索会是齐达内第二吗
  • 保证断电、碰撞等事故中车门系统能够开启!隐藏式门把手将迎来强制性国家标准
  • 陕西澄城樱桃在上海推介,向长三角消费者发出“甜蜜之邀”
  • 又一日军“慰安妇”制度受害者去世,大陆登记在册幸存者仅剩7人
  • 中邮保险斥资8.69亿元举牌东航物流,持股比例达5%
  • 苹果用户,安卓来“偷心”