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

原文:http://www.cnblogs.com/jonneydong/archive/2012/03/02/2418743.html

服务端代码:

//创建服务端,管道实例
NamedPipeServerStream serverStream = new NamedPipeServerStream("test2PIPE",
    PipeDirection.InOut,
    1,
    PipeTransmissionMode.Message,
    PipeOptions.Asynchronous);
private void Form1_Load(object sender, EventArgs e)
{
    //启用线程接收消息
    ThreadPool.QueueUserWorkItem(delegate
    {
        serverStream.BeginWaitForConnection((o) =>
        {
            NamedPipeServerStream server = (NamedPipeServerStream)o.AsyncState;
            server.EndWaitForConnection(o);
            StreamReader sr = new StreamReader(server);
            StreamWriter sw = new StreamWriter(server);
            string result = null;
            string clientName = server.GetImpersonationUserName();
            while (true)
            {
                result = sr.ReadLine();
                if (result == null || result == "bye")
                    break;
                this.Invoke((MethodInvoker)delegate
                {
                    listBox1.Items.Add(clientName + ":" + result);
                });
            }
        }, serverStream);
    });

}

客户端代码:

        //创建客户端连接实例
        NamedPipeClientStream clientStream = new NamedPipeClientStream("127.0.0.1",
            "test2PIPE",
            PipeDirection.InOut, PipeOptions.Asynchronous,
            System.Security.Principal.TokenImpersonationLevel.None
            );
        StreamWriter sw = null;
        private void Form1_Load(object sender, EventArgs e)
        {
            //连接管道
            clientStream.Connect();
            sw = new StreamWriter(clientStream);
            sw.AutoFlush = true;
        }

        private void button1_Click(object sender, EventArgs e)
        {
            //向管道中写入内容
            sw.WriteLine(richTextBox1.Text);
        }

显示结果:

经发现,命名管道, 其实是基于TCP/IP 来连接. 且端口为 445

当然, 我这里只是 传输一个字符串做为信息而已.! 其实仍然 可以传输自己所定义的 对象 等.(记得序列化哟..)

时间: 2024-08-12 15:18:51

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

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

原文地址:http://www.cnblogs.com/yukaizhao/archive/2011/08/08/namedpipeserverstream-example.html 本文介绍命名管道使用实例,文中例子是几个客户端都通过一台服务器获得新生成的int类型id. 服务器端功能:当客户端请求一个新的id时,将现有id自增1,然后返回给客户端. 服务器端实现:在程序启动时,启动n个线程,在每个线程中都声明一个NamedPipeServerStream的实例,并循环的WaitForConn

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