# .NET Framework中使用命名管道进行进程间通信

.NET Framework中使用命名管道进行进程间通信

在.NET应用程序中,进程间通信(IPC)是一项常见需求。命名管道提供了一种高效、可靠的方式来在独立运行的进程之间传输数据。本文将展示如何在.NET Framework环境下创建一个WinForms管道客户端应用程序和一个控制台管道服务器应用程序。

WinForms 管道客户端(PipeClientForm.cs)

WinForms应用程序将作为管道的客户端,接收来自服务器的数据,并更新其UI。

初始化项目和控件

首先,在Visual Studio中创建一个新的WinForms应用程序。在主窗体上,我们添加一个ProgressBar和一个Label控件,用于显示从管道接收到的数据。

实现管道连接逻辑

我们使用NamedPipeClientStream来连接到命名管道服务器。由于.NET Framework 4.5.2不支持ConnectAsync方法,我们将在后台任务中使用同步的Connect方法。

csharp 复制代码
private void ConnectToPipeServer()
{
    reconnectTimer.Stop();

    if (pipeClient != null && pipeClient.IsConnected)
    {
        return;
    }

    Task.Run(() =>
    {
        try
        {
            pipeClient = new NamedPipeClientStream(".", "TestPipe", PipeDirection.In);
            pipeClient.Connect(10000); // 10秒超时
            reader = new StreamReader(pipeClient);
            BeginListening();
        }
        catch (Exception ex)
        {
            BeginInvoke(new Action(() => MessageBox.Show($"Error connecting to pipe: {ex.Message}")));
            reconnectTimer.Start();
        }
    });
}

读取和处理数据

使用StreamReader读取从管道接收到的数据。我们假设数据是JSON格式的,包含进度和描述字段。

csharp 复制代码
private void BeginListening()
{
    try
    {
        while (!reader.EndOfStream)
        {
            var message = await reader.ReadLineAsync();
            UpdateUI(message);
        }
    }
    catch (Exception ex)
    {
        BeginInvoke(new Action(() => MessageBox.Show($"Error reading from pipe: {ex.Message}")));
        reconnectTimer.Start();
    }
}

实现重连机制

如果连接失败,我们希望客户端能够自动重试。我们使用System.Windows.Forms.Timer来实现这一点。

控制台应用程序作为管道服务器

在另一个项目中,我们创建一个控制台应用程序来作为管道的服务器。

发送数据

服务器使用NamedPipeServerStream发送数据。我们将数据格式化为JSON字符串。

csharp 复制代码
private static async Task SendMessageAsync(NamedPipeServerStream pipeStream, PipeMessage message)
{
    var jsonString = JsonConvert.SerializeObject(message);
    byte[] buffer = Encoding.UTF8.GetBytes(jsonString + "
");
    await pipeStream.WriteAsync(buffer, 0, buffer.Length);
}

运行和测试

启动服务器应用程序并等待客户端连接。接着,运行WinForms客户端应用程序。客户端应该能够连接到服务器,并开始接收数据。

总结

本文展示了如何在.NET Framework中使用命名管道进行IPC。通过命名管道,我们能够在独立的进程之间高效地传输数据,这对于需要快速、轻量级IPC的.NET应用程序来说是理想的选择。

相关推荐
缺点内向1 天前
C#: 告别繁琐!轻松移除Word文档中的文本与图片水印
c#·自动化·word·.net
2501_930707781 天前
使用 C# .NET 从 PowerPoint 演示文稿中提取背景图片
c#·powerpoint·.net
向上的车轮1 天前
为什么.NET(C#)转 Java 开发时常常在“吐槽”Java:checked exception
java·c#·.net
波波0071 天前
每日一题:.NET 的 GC是如何分代工作的?
算法·.net·gc
波波0072 天前
每日一题:中间件是如何工作的?
中间件·.net·面试题
无风听海2 天前
.NET 10之可空引用类型
数据结构·.net
码云数智-园园2 天前
基于 JSON 配置的 .NET 桌面应用自动更新实现指南
.net
无风听海2 天前
.NET 10 之dotnet run的功能
.net
岩屿2 天前
Ubuntu下安装Docker并部署.NET API(二)
运维·docker·容器·.net
码云数智-大飞2 天前
.NET 中高效实现 List 集合去重的多种方法详解
.net