c#进程间通讯方案之IPC通道

转载 2011年01月10日 17:10:00

c#进程间通讯方案之IPC通道

2010年12月05日 | 分类:开发笔记 | 标签:c#编程

最近一直纠结与使用多进程还是多线程来构建程序。多线程的方法似乎不错,但是一个进程可承受的线程数有有限的,并且由于每个线程都与UI有着些许关系,线程的工作大多数时间浪费在阻塞上了,效率实在不是很高。

笔者遂在google上搜索进程间通讯的方案。发现有很多种,其中IPC通道似乎是个不错的选择,支持本机的进程间通讯,可以作为备选方案之一,下面介绍以下基本的编程方法,以作备忘。

首先建立一个IPC通讯中使用的对象,其中MarshalByRefObject 是必须的

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
using System;
  
namespace Ipctest
{
    public class test:MarshalByRefObject
    {
        private int iCount = 0;
        public int count()
        {
            iCount++;
            return iCount;
        }
  
        public int Add(int x)
        {
            iCount += x;
            return iCount;
        }
    }
}

接着建一个服务端控制台程序

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
using System;
using System.Runtime.Remoting;
using System.Runtime.Remoting.Channels;
using System.Runtime.Remoting.Channels.Ipc;
  
namespace Ipctest
{
    class Program
    {
        static void Main(string[] args)
        {
           IpcChannel serverchannel = new IpcChannel("testchannel");
            ChannelServices.RegisterChannel(serverchannel,false);
            RemotingConfiguration.RegisterWellKnownServiceType(typeof(test), "test", WellKnownObjectMode.Singleton);
            Console.WriteLine("press Enter to exit");
            Console.ReadLine();
            Console.WriteLine("server stopped");
        }
    }
}

最后是客户端控制台程序

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
using System;
using System.Runtime.Remoting;
using System.Runtime.Remoting.Channels;
using System.Runtime.Remoting.Channels.Ipc;
  
namespace Ipctest
{
    class Program
    {
        static void Main(string[] args)
        {
            IpcChannel tcc = new IpcChannel();
            ChannelServices.RegisterChannel(tcc,false);
            WellKnownClientTypeEntry remotEntry = new WellKnownClientTypeEntry(typeof(test), "ipc://testchannel/test");
            RemotingConfiguration.RegisterWellKnownClientType(remotEntry);
  
            test st = new test();
            Console.WriteLine("{0},{1}",st.count(),st.Add(1));
            Console.ReadLine();
        }
    }
}

在测试的过程中会发现第一次调用客户端输出结果:
1,2
第二次输出结果
3,4
……
结果是比较符合要求的。

利用IPC通道进行进程间通信(C#)

有一个解决方案,其中包括一个Windows服务和一个Windows应用程序,两者之间需要进行通信。查了下,可以使用多种方法,如Web service(适用于不同系统及跨平台情况)、.NET Remot...

Android AIDL实现进程间通讯IPC

  • 2016年01月22日 14:00
  • 1.85MB
  • 下载

IPC进程间通讯

  • 2013年06月07日 15:22
  • 797KB
  • 下载

Linux 进程间通讯(IPC)详细总结 6本地套接字。

6本地套接字    1)套接字可用于一个进程和其他进程互通信息.即可以实现本地计算机通信,也可以用于网络通信. 2)套接字不同与管道,即它们是双向通信. 3)创建通用套接字的系统调用是socke...
  • x32sky
  • x32sky
  • 2011年12月18日 10:00
  • 1258

stem V 进程间通讯(IPC、ftok)

消息队列、信号灯、共享内存常用在Linux服务端编程的进程间通信环境中。而此三类编程函数在实际项目中都是用System V IPC函数实现的。System V IPC函数名称和说明如下表15-1所示。...

【IPC进程间通讯之一】邮槽MailSlot

IPC进程间通信+邮槽MailSlot                IPC(Inter-Process Communication,进程间通信)。        现代计算机采用虚拟内存机制,为进程提...

Android开源项目之Music (二)--- AIDL实现IPC进程间通讯

根据上一篇  Android开源项目之Music (一)--- MusicBrowserActivity 提到的,要继续往下分析源代码的话,需要具备AIDL的知识,如果有这方面知识的大神们请自行跳过...

Linux 进程间通讯(IPC)方式 ------- 共享内存

Linux 进程间通讯(IPC)方式有以下几种: 1-》管道(pipe)和有名管道(fifo). 2-》消息队列 3-》共享内存 4-》信号量 5-》信号(signal) 6-》套接字(s...

System V 进程间通讯(IPC、ftok)

消息队列、信号灯、共享内存常用在Linux服务端编程的进程间通信环境中。而此三类编程函数在实际项目中都是用System V IPC函数实现的。System V IPC函数名称和说明如下表15-1所示。...

Android IPC进程间通讯机制

------- android培训、java培训、期待与您交流! ---------- 第1节 面向对象(static关键字) 1.1 static关键字 用于修饰成员(成员变量和成员函数) 1.2 ...
内容举报
返回顶部
收藏助手
不良信息举报
您举报文章:c#进程间通讯方案之IPC通道
举报原因:
原因补充:

(最多只允许输入30个字)