【第22期】观点:IT 行业加班,到底有没有价值?

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

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

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

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

最近一直纠结与使用多进程还是多线程来构建程序。多线程的方法似乎不错,但是一个进程可承受的线程数有有限的,并且由于每个线程都与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
……
结果是比较符合要求的。

举报

相关文章推荐

[转载]android操作系统

1. BP部分与AP部分的集成。2. 传统的功能手机只配备了出厂时预装的应用软件,而不允许用户自主下载并安装第三方应用软件,而智能手机突破了这一限制,因此智能手机的AP部分,必须有相应的开放机制,方便第三方软件的开发与安装,同时尽可能降低第三方软件造成对整个系统,包括其它软件的恶意伤害。更进一步说,智能手机的开放机制,不仅针对第三方软件,而且也针对手机生产厂家,允许手机生产厂家更换手机系统的部分硬件设备,或者增设其它外设硬件设备,做到一个通用平台可以出货多个手机型

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

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

欢迎关注CSDN程序人生公众号

关注程序员生活,汇聚开发轶事。

Android IPC进程间通讯机制

Android IPC进程间通讯机制 2011年06月17日   一.Linux系统进程间通信有哪些方式? 1.socket; 2.name pipe命名管道; 3.message queue消息队列; 4.singal信号量; 5.share memory共享内存;   二.Java系统的通信方式是什么? 1.socket; 2.name pipe;   三.Android系统通信方式是什么? Binder 通信;   四.Binder通信的优势是什么? 高效率   五.Binder通信的特点是什么? 是同步,而不是异步;   六.Binder通信是如何实现

进程间的通讯——IPC通道

内部进程通讯,是指在同一台计算机当中的不同进程之间进行通讯。 对于两个进程之间的通讯方式有很多种,比如文件共享,Socket通讯,管道等,这里主要讲的是通过IPC Channel的方式 主要用到的命名...

Android IPC进程间通讯机制

Android IPC进程间通讯机制 2011年06月17日   一.Linux系统进程间通信有哪些方式? 1.socket; 2.name pipe命名管道; 3.message queue消息队列; 4.singal信号量; 5.share memory共享内存;   二.Java系统的通信方式是什么? 1.socket; 2.name pipe;   三.Android系统通信方式是什么? Binder 通信;   四.Binder通信的优势是什么? 高效率   五.Binder通信的特点是什么? 是同步,而不是异步;   六.Binder通信是如何实现
收藏助手
不良信息举报
您举报文章:深度学习:神经网络中的前向传播和反向传播算法推导
举报原因:
原因补充:

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