最近一直纠结与使用多进程还是多线程来构建程序。多线程的方法似乎不错,但是一个进程可承受的线程数有有限的,并且由于每个线程都与UI有着些许关系,线程的工作大多数时间浪费在阻塞上了,效率实在不是很高。
笔者遂在google上搜索进程间通讯的方案。发现有很多种,其中IPC通道似乎是个不错的选择,支持本机的进程间通讯,可以作为备选方案之一,下面介绍以下基本的编程方法,以作备忘。
首先建立一个IPC通讯中使用的对象,其中MarshalByRefObject 是必须的
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;
}
}
}
接着建一个服务端控制台程序
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");
}
}
}
最后是客户端控制台程序
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
……
结果是比较符合要求的。



