如果您对.NET远程处理或者是从事过有关Socket相关的编程,那么您可能会对以上两个概念不会很陌生.其实信道工厂和信道监听器的概念在.NET远程处理和Socket中就提到过,只是在WCF中的这两个概念更加灵活.那么究竟他们主要用来做什么了? 我可以给您打一个比方,当需要建立通信的时候,首先的必备条件就是需要一个请求发送端,以及一个请求接受端,这就是在分布式编程中的客户端和服务器端,服务器端为客户端的请求提供服务,如果您对通信协议了解的话,可能会知道通信方式一般有三种,单工通信,双工通信和半双工通信.同时在WCF中也涉及到这些概念,那么这些概念具体体现在哪里了? 就是信道工厂和信道监听器.信道工厂和信道监听器只是客户端和服务器端建立通信的容器,它里面包含了信道的形状,以及中介点,承载服务的资源描述以及绑定,虽然微软在发布WCF时说给了开发人员足够的灵活性,实事上是要大打折扣的.当在创建自定义的信道工厂和信道监听器时,只是重载了一些方法.我觉得这对于要扩展使用WCF这已经足够了.同时我们还需要了解信道工厂的这种机制,当上层服务需要使用新到工厂发送请求时,信道工厂会创建一个内部的信道工厂,而自己继续等待并为上层服务.这种机制有些像IIS中的应用程序池.说道这就可以看具体实现的代码了:

代码

1 /// <summary>
2 /// 继承自ChannelFactory实现自主创建信道工厂,在绑定元素中的创建信道工厂使用
3 /// </summary>
4 /// <typeparam name="TChannel"></typeparam>
5   class MyChannelFactory<TChannel>: ChannelFactoryBase<IRequestChannel>
6 {
7 IChannelFactory<TChannel> innerChannelFactory = null;
8
9 /// <summary>
10 /// 为内部创建的变量信道工厂初始化,使用绑定元素
11 /// </summary>
12 /// <param name="bindingElement"></param>
13 /// <param name="context"></param>
14   public MyChannelFactory(MyBindingElement bindingElement, BindingContext context) : base(context.Binding)
15 {

17 this.innerChannelFactory = context.BuildInnerChannelFactory<TChannel>();
18 if (this.innerChannelFactory == null)
19 {
20 throw new InvalidOperationException("MyCustomChannelFactory requires an inner IChannelFactory.");
21 }
22 }
23
24 //创建请求信道,请求信道基于创建的内部信道工厂
25 protected override IRequestChannel OnCreateChannel(System.ServiceModel.EndpointAddress address, Uri via)
26 {

28 IRequestChannel innerChannel = (IRequestChannel)this.innerChannelFactory.CreateChannel(address, via);
29 return new MyCustomRequestChannel(innerChannel);
30
31 }
32
33 protected override IAsyncResult OnBeginOpen(TimeSpan timeout, AsyncCallback callback, object state)
34 {
35 throw new Exception("The method or operation is not implemented.");
36 }
37
38 protected override void OnEndOpen(IAsyncResult result)
39 {
40 throw new Exception("The method or operation is not implemented.");
41 }
42
43 protected override void OnOpen(TimeSpan timeout)
44 {

46 this.innerChannelFactory.Open(timeout);
47 }
48

您可能也发现了,在整个创建信道工厂的时候,主要只是涉及到了几个函数,同时通过这,也可以间接了解到WCF的整个结构.最重要的就是初始化函数和创建信道函数,其他均是为了实现异步操作的扩展,同时在这里也发现了当调用开启信道工厂的时候,并不是开启他本身,而是开启内部创建的信道工厂,此时我觉得如果对信道工厂还有什么疑问的话,就该就是内部如何实现多线程的.这个问题以后有时间再探讨.在构造函数里涉及到了绑定,其实绑定在此处的作用很单一,确定传输协议.那么接着您就又会问绑定上下文,其实微软几乎在他所有的架构技术中会都涉及到上下文,上下文只是记录当先环境中与当前概念相关的信息.要理解上下文必须从整个体系了解.在这个里面信道形状通过范型来实现.接下来介绍关于新到监听器,信道监听器可以间接理解为系统中开启的服务,其实它就是开启的后台服务,他一直在等待客户端的调用.它里面的函数要比信道工厂多用一些,下面是创建自定义信道监听器的代码:

代码

1 namespace Extensibility
2 {
3 class MyChannelListener<TChannel>: ChannelListenerBase<IReplyChannel> where TChannel: class, IChannel
4 {
5 IChannelListener<TChannel> innerChannelListener = null;
6
7 //创建内部监听信道,又传递过来的绑定上下文创建
8 public MyChannelListener(MyCustomBindingElement bindingElement, BindingContext context)
9 : base(context.Binding)
10 {

12 this.innerChannelListener = context.BuildInnerChannelListener<TChannel>();
13 if (this.innerChannelListener == null)
14 {
15 throw new InvalidOperationException("MyCustomChannelListener requires an inner IChannelFactory.");
16 }
17
18 }
19
20
21
22
23 protected override IReplyChannel OnAcceptChannel(TimeSpan timeout)
24 {
25 throw new Exception("The method or operation is not implemented.");
26 }
27
28 protected override IAsyncResult OnBeginAcceptChannel(TimeSpan timeout, AsyncCallback callback, object state)
29 {
31 return this.innerChannelListener.BeginAcceptChannel(timeout, callback, state);
32 }
33
34 //接受信道
35 protected override IReplyChannel OnEndAcceptChannel(IAsyncResult result)
36 {
38 IReplyChannel replyChannel = ((IReplyChannel)this.innerChannelListener.EndAcceptChannel(result));
39 if (replyChannel == null)
40 {
41 return null;
42 }
43 return new MyCustomReplyChannel(replyChannel);
44 }
45
46 protected override IAsyncResult OnBeginWaitForChannel(TimeSpan timeout, AsyncCallback callback, object state)
47 {
48 throw new Exception("The method or operation is not implemented.");
49 }
50
51 protected override bool OnEndWaitForChannel(IAsyncResult result)
52 {
53 throw new Exception("The method or operation is not implemented.");
54 }
55
56 protected override bool OnWaitForChannel(TimeSpan timeout)
57 {
58 throw new Exception("The method or operation is not implemented.");
59 }
60
61 public override Uri Uri
62 {
63 get
64 {
66 return this.innerChannelListener.Uri;
67 }
68 }
69
70 protected override void OnAbort()
71 {
72 throw new Exception("The method or operation is not implemented.");
73 }
74
75 protected override IAsyncResult OnBeginClose(TimeSpan timeout, AsyncCallback callback, object state)
76 {
77 throw new Exception("The method or operation is not implemented.");
78 }
79
80 protected override IAsyncResult OnBeginOpen(TimeSpan timeout, AsyncCallback callback, object state)
81 {
82 throw new Exception("The method or operation is not implemented.");
83 }
84
85 protected override void OnClose(TimeSpan timeout)
86 {

88 this.innerChannelListener.Close(timeout);
89 }
90
91 protected override void OnEndClose(IAsyncResult result)
92 {
93 throw new Exception("The method or operation is not implemented.");
94 }
95
96 protected override void OnEndOpen(IAsyncResult result)
97 {
98 throw new Exception("The method or operation is not implemented.");
99 }
100
101 protected override void OnOpen(TimeSpan timeout)
102 {
104 this.innerChannelListener.Open(timeout);
105
106 }
107 }
108 }
109

在信道工厂中存在创建信道,在这就存在接受信道,他所涉及的其他概念也与信道工厂类似,它与信道工厂唯一的区别在于关闭信道的机制上,对于信道工厂必须等到内部信道关闭后,才能关闭上层的信道工厂.如果您存在一些关于WCF开发和使用的问题,很乐意帮您解决.

转载于:https://www.cnblogs.com/shareExperience/archive/2010/07/14/1777553.html

WCF之自定义信道工厂,信道监听器相关推荐

  1. 接收机的阻塞性能 相邻信道 相间信道

    接收机的阻塞性能如下表2-2所示,相邻信道是在频率上最接近期望信道 的信道,而相间信道则是相对主信道离开相邻信道更远的一个信道. 表2-2接收机抗干扰性的最低要求 相邻信道抑制        相间信道 ...

  2. WIFI中的频段、信道、信道带宽

    一.波长.波速与频率 波长=波速/频率 "波速"由"介质"决定. "频率"由"波源"决定. "波长" ...

  3. 下行物理信道rs_信道估计与均衡

    在LTE系统中采用了MIMO技术,多天线收发.由于天线之间的物理位置差异,收发双方通过多根天线之间的位置关系产生了多种不同的收发路径效果,如果这多种路径效果最终能很有效的结合起来互相弥补不足,则可以达 ...

  4. matlab仿真散射信道,无线信道建模原理及SUI-3信道的MATlab仿真.doc

    无线信道建模原理及SUI-3信道的MATlab仿真 无线衰落信道及仿真 无线衰落信道 在无线移动信道中,信号从发射天线经过复杂的传播环境到达接收天线,接收信号为各反射.衍射和散射分量以及信道噪声的复合 ...

  5. java 线程工厂_Java并发编程:Java的四种线程池的使用,以及自定义线程工厂

    引言 通过前面的文章,我们学习了Executor框架中的核心类ThreadPoolExecutor ,对于线程池的核心调度机制有了一定的了解,并且成功使用ThreadPoolExecutor 创建了线 ...

  6. zstack信道_Zigbee信道原理

    Zigbee 信道原理 物理层上面是 mac 层,它的核心是信道接入技术, 包括 GTS (时分复用技术) 和随机信道接 入技术( csma-ca ) .不过 zigbee 没有对 gts 技术进行支 ...

  7. GSM的逻辑信道-业务信道(TCH)

    基本概念 业务信道(TCH:Traffic CHannel),用于传送编码后的话音或用户数据,在上行和下行信道上,点对点(BTS对一个MS,或反之)方式传播. 解释说明 话音业务信道主要分为以下三类: ...

  8. GSM的逻辑信道-控制信道-专用控制信道(DCCH

    基本概念 专用控制信道(DCCH:Dedicated Control CHannel):是一种"点对点"的双向控制信道,其用途是在呼叫接续阶段和在通信进行当中,在移动台和基站之间传 ...

  9. 信道估计 信道均衡 动态均衡 盲均衡 半盲均衡 自适应均衡……

    有一些相关的名词,如:信道估计.信道均衡.盲均衡.非盲均衡.半盲均衡.动态均衡-- 首先,当信号在信道中传输时,会因信道环境而使信号受到恶化,我们希望能够量化出这种恶化,可能是具体的数学表达式,也可能 ...

最新文章

  1. struts2入门(搭建环境、配置、示例)
  2. java ssl证书生成_java – 使用jdk中提供的keytool生成SSL证书
  3. 计算机错误2 找不到指定文件,无法执行目录中的文件 错误2系统找不到指定文件怎么办?...
  4. cocos2d-x lua table数据存储
  5. 电脑备忘录软件测试自学,软件测试经验和教训分享.pdf
  6. amd u盘安装linux mint,安装Linux Mint 20后需要做的13件事
  7. 谨防 ActiveSupport::Cache::Store 缓存 nil 值
  8. [swift] LeetCode 234. Palindrome Linked List
  9. 记忆化搜索--poj 1597 Function Run Fun
  10. landsat8简介
  11. openxml html to word,使用openxml提取word中的文本和图片并转为Html
  12. android时钟计时器代码,android的Handle计时器实现代码
  13. mame android版本,重整街机模拟器MAME(Android版)
  14. Java核心技术 卷一 - 第 1 章 Java 程序设计概述
  15. ADAMoracle去中心化预言机价值核心在哪
  16. Zemax学习笔记(11) - 变焦镜头设计实例
  17. 数列极限的四则运算法则
  18. vs2013+opencv3.4.3配置安装教程
  19. 1750套工装夹具检具治具机械设计机构solidworks模型3d课程图纸sw
  20. layUI基本使用2(js)

热门文章

  1. java api 调用 kettle 执行etl任务
  2. windows下scrapy安装问题,以及Twisted安装报错(error: Microsoft Visual C++ 14.0 is required.)完美解决办法...
  3. C#_Math函数总结
  4. [LeetCode 111] - 二叉树的最小深度 (Minimum Depth of Binary Tree)
  5. JSP、JAVA获取各种路径总结
  6. 在asp.net2.0中使用串行化对象实现自定义配置
  7. 在ComboBox控件中使用嵌入字体。
  8. Timer的缺陷 用ScheduledExecutorService替代
  9. Binder通信中的代理模式
  10. Android:面试官死亡问答,如何优化一个网络请求?大牛多个网络优化方案帮你解决!