命名管道跨进程通信实例1(转)

原文地址:http://www.cnblogs.com/yukaizhao/archive/2011/08/08/namedpipeserverstream-example.html

本文介绍命名管道使用实例,文中例子是几个客户端都通过一台服务器获得新生成的int类型id。

服务器端功能:当客户端请求一个新的id时,将现有id自增1,然后返回给客户端。

服务器端实现:在程序启动时,启动n个线程,在每个线程中都声明一个NamedPipeServerStream的实例,并循环的WaitForConnection(),将新的id写入到命名管道中,然后断开连接。在程序退出时释放NamedPipeServerStream实例

服务器端代码:

class Program
{
    //命名管道名字
    private const string PIPE_NAME = "testpipe";
    //定义线程数,也是NamedPipeServerStream的允许最多的实例数
    private const int MAX_THREAD_COUNT = 3;

    private static volatile int _runingThreadCount = 0;
    private static volatile int _newID = 0;

    private static NamedPipeServerStream[] _serverStreams;

    static void Main(string[] args)
    {
        _serverStreams = new NamedPipeServerStream[MAX_THREAD_COUNT];
        //在进程退出时,释放所有NamedPipeServerStream实例
        AppDomain.CurrentDomain.ProcessExit += new EventHandler(CurrentDomain_ProcessExit);
        //启动线程
        StartServers();
        Console.Read();
    }
    /// <summary>
    /// 进程退出时释放命名管道
    /// </summary>
    /// <param name="sender"></param>
    /// <param name="e"></param>
    static void CurrentDomain_ProcessExit(object sender, EventArgs e)
    {
        if (_serverStreams != null)
        {
            foreach (NamedPipeServerStream item in _serverStreams)
            {
                item.Dispose();
            }
        }
    }
    /// <summary>
    /// 启动线程
    /// </summary>
    private static void StartServers()
    {
        for (int i = 0; i < MAX_THREAD_COUNT; i++)
        {
            Thread thread = new Thread(new ThreadStart(StartNewIDServer));
            thread.Start();
        }
    }
    /// <summary>
    /// 启动一个NamedPipeServerStream实例
    /// </summary>
    private static void StartNewIDServer()
    {
        NamedPipeServerStream stream = null;
        Console.WriteLine("start server in thread:" + Thread.CurrentThread.ManagedThreadId);

        stream = _serverStreams[_runingThreadCount] = new NamedPipeServerStream(PIPE_NAME,
            PipeDirection.InOut,
            MAX_THREAD_COUNT,
            PipeTransmissionMode.Message,
            PipeOptions.None);
        while (true)
        {
            stream.WaitForConnection();

            int newID = ++_newID;
            byte[] bytes = BitConverter.GetBytes(newID);
            stream.Write(bytes,0,bytes.Length);
            stream.Flush();
            Console.WriteLine("threadNo:"+Thread.CurrentThread.ManagedThreadId+"\r");
            stream.Disconnect();
        }
    }
}

客户端的功能是不断的发出获得新id的请求,并打印新id,在客户端可以配置服务端的服务器IP。

客户端代码:

class Program
{
    private const string PIPE_NAME = "testpipe";
    static void Main(string[] args)
    {
        Console.WriteLine("请输入任何字符回车开始执行程序...");
        Console.Read();
        do
        {
            //内网服务器IP,必须是局域网
            string serverName = "127.0.0.1";
            //声明NamedPipeClientStream实例
            using (NamedPipeClientStream clientStream=new NamedPipeClientStream(
                serverName,
                PIPE_NAME
                ))
            {
                //连接服务器
                clientStream.Connect(1000);
                //设置为消息读取模式
                clientStream.ReadMode = PipeTransmissionMode.Message;
                do
                {
                    byte[] bytes = new byte[4];
                    clientStream.Read(bytes,0,4);
                    int val = BitConverter.ToInt32(bytes,0);
                    Console.WriteLine("NewID=="+val+"\r");
                } while (!clientStream.IsMessageComplete);
            }
            Thread.Sleep(1);
        } while (true);
    }
}

在sql server中就使用了命名管道在局域网内挂进程通讯。

在声明NamedPipeServerStream实例是可以指定其实例个数,如果实例数超过这个数,就会抛出“所有管道范例都在使用中”的IO异常。

本例不可以在实际项目中使用。

程序源码下载

时间: 2024-12-06 23:16:04

命名管道跨进程通信实例1(转)的相关文章

命名管道跨进程通信实例2(转)

原文:http://www.cnblogs.com/jonneydong/archive/2012/03/02/2418743.html 服务端代码: //创建服务端,管道实例 NamedPipeServerStream serverStream = new NamedPipeServerStream("test2PIPE", PipeDirection.InOut, 1, PipeTransmissionMode.Message, PipeOptions.Asynchronous);

C#中使用命名管道进行进程通信的实例

原文:C#中使用命名管道进行进程通信的实例 1 新建解决方案NamedPipeExample 在解决方案下面新建两个项目:Client和Server,两者的输出类型均为"Windows 应用程序".整个程序的结构如下图所示. 2 实现项目Client Client仅包含一个名为"客户端"的窗体,如下图所示. 编写窗体后端代码,如下所示. using System; using System.IO; using System.IO.Pipes; using Syste

命名管道跨进程通讯

客户端代码: #include "stdafx.h" #include <stdio.h> #include <windows.h> #include <ctime> int main(int argc, _TCHAR* argv[]) { srand(time(NULL)); DWORD wlen = 0; Sleep(1000);//等待pipe的创建成功! BOOL bRet = WaitNamedPipe(TEXT("\\\\.\\

C++ 命名管道 与Winform跨进程通信

以下是.NET命名管道解决方案中几个主要的类. NamedPipeNative:这个类和kernal32.dll联系实现命名管道的通信,其中包含一些常用方法和常量. NamedPipeWrapper :这个类是NamedPipeNative的一个包装. BasepipeConnection:这是一个抽象类,定义了命名管道连接.读.写数据的方法.这个类是从ClientPipeConnection 和ServerPipeConnection 继承的,分别在客户端和服务器端应用程序中使用. Clien

Android中的跨进程通信方法实例及特点分析(二):ContentProvider

1.ContentProvider简单介绍 在Android中有些数据(如通讯录.音频.视频文件等)是要供非常多应用程序使用的.为了更好地对外提供数据,Android系统给我们提供了Content Provider使用,通过它能够訪问上面所说的数据.比如非常多音乐播放器中的扫描功能事实上就用到了Content Provider功能(当然,也有的播放器是自己去实现更底层的功能). 这种优点是统一管理,比方添加了某个音频文件,底层就会将这种变化通知Content Provider.从而当应用程序訪问

Android中的跨进程通信方法实例及特点分析(一):AIDL Service

转载请注明出处:http://blog.csdn.net/bettarwang/article/details/40947481 最近有一个需求就是往程序中加入大数据的采集点,但是因为我们的Android程序包含两个进程,所以涉及到跨进程通信的问题.现将Android中的跨进程通信方式总结如下. Android中有4种跨进程通信方式,分别是利用AIDL Service.ContentProvider.Broadcast.Activity实现. 1.利用AIDL Service实现跨进程通信 这是

【朝花夕拾】一篇文章搞懂Android跨进程通信

前言 只要是面试中高级工程师岗位,Android跨进程通信就是最受面试官青睐的知识点.Android系统的运行由大量相互独立的进程相互协助来完成的,所以Android进程间通信问题,是做好Android开发高级工程师必须要跨过的一道坎.如果您还对这方面的知识还做不到如数家珍,那就和我一起来攻克它吧! 本文主要包含了如下内容: 其行文脉络大致如下,希望能加深读者对这方面内容的记忆:(1)Android基于Linux系统,所以先说系统进程相关知识和Linux IPC.(2)总结Android的IPC

linux 单机跨进程通信

一般来说通过网络通信(比如tcp,udp)或者共享内存的方式肯定可以实现跨进程通信,但现在这里要说的是比较偏但实用的几个方法:利用unix域通信(普通网络连接),利用unix域通信(socketpair通信),以及pipe方式. 一. 利用unix域通信(普通网络连接) socket API原本是为网络通讯设计的,但后来在socket的框架上发展出一种IPC机制,就是UNIX Domain Socket.虽然网络socket也可用于同一台主机的进程间通讯(通过loopback地址127.0.0.

Android基础笔记(十二)- 使用AIDL来进行跨进程通信

绑定服务调用服务里方法的过程 音乐盒小案例 利用服务注册特殊广播接收者 使用AIDL来进行跨进程通信 绑定服务调用服务里方法的过程 整个Activty绑定Service并调用其中方法的过程可以体现为下面的一张图,其中的核心是通过借助中间人IBinder来达到调用Service中方法的目的.. 接下来在明确一下调用过程的代码步骤: ①首先服务里有一个方法需要被调用 ②定义一个中间人对象(继承Bidner类的内部类MyBinder) ③在onBind方法中把我们自己定义的中间人返回MyBinder