这篇讲一下AChannel基类和其相关的派生类。AChannel类看名字应该是频道的意思,看代码是和消息内容相关的类。

  • AChannel

关于AChannel在我之前的文章里面有讲到过,大家可以看这里。 内容不是很多,主要是定义了两个事件,用于放置回调方法。还有和这两个事件相关的调用方法。以及一些其他。

  • KChannel

框架中有3个Channel,分别对应TcpKcpWebScoket三种网络协议。这里的KChannel对应的及时Kcp。这里面还有一个结构体,很简单,可以看看:看名称该是用于存放待发送的消息。

public struct WaitSendBuffer
{public byte[] Bytes;public int Length;public WaitSendBuffer(byte[] bytes, int length){this.Bytes = bytes;this.Length = length;}
}

构造参数有两个,有注释,看起来这个类是客户端与服务端都可以使用的,不过这只是猜测。在创建Channel的时候,都会默认创建一个对应的KServer对象。同时我们指定了该Channel传输数据所使用的流。同时创建了一个kcp连接,设置了kcp的一些属性。最后调用了一个Accept方法。

Accept方法,里面有一句Socket.SendTo方法,应该就是发送了一个消息,从内存流中获取字节数组内容后,将字节数组的0位置的元素替换成KcpProtocalType.ACK,这应该是一个用于识别的标注位。然后再将数组的1到4位元素替换成和KChannel组件的Id相关的一组数字,具体算法可以看一下框架的代码。这里就是将发送给服务器的消息和该类进行了捆绑。最后再将5到8位元素替换成和远程服务器地址相关的一组数字。这就相当于是在消息中加入了远程服务端的相关信息,可以用于消息验证。

public static class KcpProtocalType
{public const byte SYN = 1;public const byte ACK = 2;public const byte FIN = 3;public const byte MSG = 4;
}

第二个构造函数和第一个的区别在于,少了一个描述远程主机的参数。方法内部没有创建kcp连接,最后执行的是一个Connect的方法,该方法与Accept方法逻辑基本相同,不同点在于发送的消息头部的构成,具体区别不得而知。

HandleConnnect方法内部有一段创建kcp的代码,和构造函数部分的代码基本相同。最后执行了HandleSend方法,该方法通过一个无限循环,弹出sendBuffer队列中的元素,通过kcp发送出去。

后面几个方法暂时不看了,涉及到了kcp的相关知识。

  • TChannel

“封装Socket,将回调push到主线程处理”,写在开头的注释。

看内部代码,应该是用的Socket进行通信的,里面涉及到了一个类SocketAsyncEventArgs,具体可以参考这篇文章。这里有两个SocketAsyncEventArgs对象,负责接收和发送数据,对应于两个CircularBuffer对象。和KChannel一样,TChannel也有两个重载的构造函数。一个是接受的Socket参数,一个是接受的IPEndPoint参数。SocketAsyncEventArgs参数的Completed属性赋值了OnComplete方法,该属性用于判断收发数据是否成功。

OnComplete方法,会判断SocketAsyncEventArgsLastOperation属性,根据类型,将不同的回调抛回到主线程调用。

switch (e.LastOperation)
{case SocketAsyncOperation.Connect:OneThreadSynchronizationContext.Instance.Post(this.OnConnectComplete, e);break;case SocketAsyncOperation.Receive:OneThreadSynchronizationContext.Instance.Post(this.OnRecvComplete, e);break;case SocketAsyncOperation.Send:OneThreadSynchronizationContext.Instance.Post(this.OnSendComplete, e);break;case SocketAsyncOperation.Disconnect:                                    OneThreadSynchronizationContext.Instance.Post(this.OnDisconnectComplete, e);break;default:throw new Exception($"socket error: {e.LastOperation}");
}

Start方法开启Socket。会先检查Socket是否连接成功,否则会进行一次重新连接,确认连接成功后会重新执行Start方法。检查连接后,会检查接受数据,会调用StartRecv方法,看名字是开始接受数据的方法。innArgs会先设置消息内容,设置成功后。判断有没有成功收到消息,否则调用OnRecvComplete方法接受消息。这里会对Socket进行错误判断,用SocketErrorBytesTransferred结合来判断当前操作是否成功能。确认无误后,设置recvBuffer的内容,调用OnRead方法读取流对象,最后在调用StartRecv方法。

Send方法,发送数据的方法。接受一个MemoryStream参数。根据Packet.SizeLength的值,对要发送的字节数组做包装。将数据都写入流后,调用了MarkNeedStartSend方法,放入待发送的缓存里面。

  • WChannel

WebSocket的相关内容也没有接触过,不过大致上和上面两个Channel的逻辑相差无几。

ET框架学习——消息系统之四相关推荐

  1. ET框架学习——消息系统之七

    最近一直在搞这个消息流转路径,做了几张图: Connect&Recive Send 数据包装变化

  2. Flask框架flash消息闪现学习与优化符合闪现之名

    Flask的flash 第一次知道Flask有flash这个功能时,听这名字就觉得高端,消息闪现-是跳刀blink闪烁躲技能的top10操作吗?可结果让我好失望,哪里有什么闪现的效果,不过是平常的消息 ...

  3. 进程——Windows核心编程学习手札系列之四

    进程 --Windows核心编程学习手札系列之四 进程是一个正在运行的程序的实例,有两个部分组成:一个是操作系统用来管理进程的内核对象,内核对象是系统用来存放关于进程的统计信息的地方:另一个是地址空间 ...

  4. 大数据开发hadoop核心的分布式消息系统:Apache Kafka 你知道吗

    简介 Apache Kafka是分布式发布-订阅消息系统.它最初由LinkedIn公司开发,之后成为Apache项目的一部分.Kafka是一种快速.可扩展的.设计内在就是分布式的,分区的和可复制的提交 ...

  5. jQuery框架学习第十一天:实战jQuery表单验证及jQuery自动完成提示插件

    jQuery框架学习第一天:开始认识jQuery jQuery框架学习第二天:jQuery中万能的选择器 jQuery框架学习第三天:如何管理jQuery包装集  jQuery框架学习第四天:使用jQ ...

  6. 三.激光SLAM框架学习之A-LOAM框架---项目工程代码介绍---1.项目文件介绍(除主要源码部分)

    专栏系列文章如下: 一:Tixiao Shan最新力作LVI-SAM(Lio-SAM+Vins-Mono),基于视觉-激光-惯导里程计的SLAM框架,环境搭建和跑通过程_goldqiu的博客-CSDN ...

  7. Kafka消息系统基础知识索引消息

    我们在上篇文章中,详细说明了KAFKA是否适合用在业务系统中,但有些朋友,还不知道KAFKA为何物,以及它为何存在.这在工作和面试中是比较吃亏的,因为不知道什么时候起,KAFKA似乎成了一种工程师的必 ...

  8. Samza框架-----学习笔记

    Samza框架-----学习笔记 基本概念: 作业:是对一组输入流进行处理转化成输出流的程序. 分区: Samza的流数据单位既不是Storm中的元组,也不是Spark Streaming中的DStr ...

  9. 百度直播消息系统的实践和演进

    导读:直播业务的核心功能有两个,一个是实时音视频推拉流,另一个是直播间消息流的收发.本文主要介绍百度直播服务内的消息服务系统的设计实践和演化. 一.背景 直播间内用户聊天互动,形式上是常见的IM消息流 ...

  10. 高通ims架构android,深度揭密高通4/5G移动基带消息系统和状态机

    背景 本技术分析文章通过对高通的4/5G移动基带系统进行深入逆向工程提示其内部消息通信机制以及核心架构设计逻辑,本文的研究基于高通的4G基带MDM9707以及5G基带模块sdx55的固件之上分析完成, ...

最新文章

  1. fullpage的应用
  2. 【CVPR2022】双曲图像分割
  3. mysql操作命令梳理(3)-pager
  4. MathType可以在Word、PPT中插入矩阵吗
  5. java kafka 多线程消费
  6. 根据当前日期返回星期数
  7. 电脑硬盘数据线_这40种电脑故障的排除技巧你都掌握了吗?
  8. acm之java输入输出_ACM中Java输入输出
  9. jQuery 图表插件 jqChart 使用
  10. 乐高机器人编程自学入门
  11. 【IObit】五大软件激活码( Advanced Systemcare....)
  12. Canvas 画贝塞尔曲线(二阶曲线和三阶曲线)
  13. DDD如何区分实体和值对象
  14. 平安普惠i贷额度抢光
  15. 吴恩达机器学习笔记第一周
  16. 自学Android开发 AES加密
  17. Linux下的power_supply小析
  18. Android高工:细说 Android 多线程,211本硕如何通过字节跳动、百度、美团Android面试
  19. 主生产计划(MPS)及物料需求计划(MRP)
  20. 多唱点歌显示微服务器断开,多唱微服务器

热门文章

  1. matlab 模糊提取,[转载]Matlab 的fspecial函数用法 图像模糊、提取边缘
  2. JZOJ 3337. 【NOI2013模拟】wyl8899的TLE【暴力】
  3. linux命令大全 load,linux命令TOP参数load average详解[转]
  4. Orange Business Services 携手 Riverbed 将 SD-WAN 引入混合网络
  5. css相对图片加文字,html+css怎么在图片上添加文字
  6. 【区块链108将】千方基金点付大头:投资区块链,不要让过往认知限制你的想象
  7. Mac下禁用开机自启软件
  8. 数据、变量、内存三者之间的关系
  9. 一般物体检测--Binarized Normed Gradients for Objectness Estimation at 300fps
  10. SAP开发-同时定义同名的工作区、内表 OCCURS 0 WITH HEADER LINE