# .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应用程序来说是理想的选择。

相关推荐
一个帅气昵称啊11 小时前
基于.NET AgentFramework开发OpenClaw智能体框架
人工智能·自然语言处理·c#·.net·openclaw
唐青枫12 小时前
C#.NET SpinLock 深入解析:自旋锁原理、使用边界与性能取舍
c#·.net
CSharp精选营20 小时前
.NET对象转JSON,到底有几种方式?
c#·json·.net·newtonsoft·对象转换·utf8json
mudtools21 小时前
存储那么贵,何不白嫖飞书云文件空间
前端框架·c#·.net
波波00721 小时前
每日一题:请解释.NET 中的泛型约束是什么
java·面试·.net
步步为营DotNet21 小时前
解锁.NET 11 边缘计算潜力:基于Blazor与Native AOT的边缘应用开发
人工智能·.net·边缘计算
xdpcxq102921 小时前
.NET 磁盘BitLocker加密
.net
荔枝吻21 小时前
【保姆级喂饭教程】Windows各版本对.NET支持情况
windows·.net
我是唐青枫1 天前
C#.NET SignalR + Redis Backplane 深入解析:多节点部署与跨实例消息同步
c#·.net
玩泥巴的1 天前
存储那么贵,何不白嫖飞书云文件空间
c#·.net·二次开发·飞书