ET框架学习——消息系统之三

2024-04-16 21:58

本文主要是介绍ET框架学习——消息系统之三,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

       鉴于我之前对于游戏的网络开发部分没有经验。后面关于ET消息系统的学习都将参考这位朋友Norman_Lin的博客来学习。后面会自己再来调整文章的顺序,结构等。

  • CircularBuffer

      这个应该是ET框架中消息相关的类,继承自Stream类。ChunkSize字段的代表一个字节数组的最大长度。后面两个队列应该是用于存储消息流的。

public int ChunkSize = 8192;
private readonly Queue<byte[]> bufferQueue = new Queue<byte[]>();
private readonly Queue<byte[]> bufferCache = new Queue<byte[]>();
public int LastIndex { get; set; }
public int FirstIndex { get; set; }
private byte[] lastBuffer;

 Length字段的定义和bufferQueue队列的长度有关,撇开特殊情况不说,结果如下:

 Lenght = (this.bufferQueue.Count - 1) * ChunkSize + this.LastIndex - this.FirstIndex;

     CircularBuffer在实例化是会执行AddLast方法,会将bufferCache队列中的对头元素弹出(不存在则创建一个空的元素,长度为ChunkSize),做两次赋值:

this.bufferQueue.Enqueue(buffer);
this.lastBuffer = buffer;

       后面还有几个对bufferQueue队列做操作的方法,获取bufferQueue队列的对头和队尾元素,移除对头元素(重新压入bufferCache队列中)。

       后面的几个方法是对字节数组和Stream间的互相操作,关于Stream类,可以参考这篇文章。Write方法用于将steam流写入到bufferQueue队列的尾部字节数组中去。在获取到流中还有数据后,通过一个While循环来写数据(alreadyCopyCount 和count做判断)。当字节数组还有位置时,就从流中写入数据到数组中去。Read方法用于将bufferQueue队列的头部字节数组中的数据转入到流中去。逻辑和Write方法差不多,就是反一下。

// 从stream写入CircularBuffer
public void Write(Stream stream)
{int count = (int)(stream.Length - stream.Position);   // 当前流中剩下的数据长度int alreadyCopyCount = 0;   // alreadyCopyCount 代表已经从流中写入的长度(临时的)while (alreadyCopyCount < count){// this.LastIndex是一个游标,代表已经写入到数组中的数据长度if (this.LastIndex == ChunkSize){// 对队列扩容this.AddLast();this.LastIndex = 0;}int n = count - alreadyCopyCount;  // n 代表流中还未写入的数据的长度// 数组的长度 - 已经写入的长度 > 流中还未写入的数据的长度if (ChunkSize - this.LastIndex > n)  {stream.Read(this.lastBuffer, this.LastIndex, n);//  写入完成后的长度this.LastIndex += count - alreadyCopyCount;alreadyCopyCount += n;}else // 数组中的长度不够,先写满,然后扩容再将剩余的写入{stream.Read(this.lastBuffer, this.LastIndex, ChunkSize - this.LastIndex);alreadyCopyCount += ChunkSize - this.LastIndex;this.LastIndex = ChunkSize;}}
}

 

这篇关于ET框架学习——消息系统之三的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/910007

相关文章

Linux系统中查询JDK安装目录的几种常用方法

《Linux系统中查询JDK安装目录的几种常用方法》:本文主要介绍Linux系统中查询JDK安装目录的几种常用方法,方法分别是通过update-alternatives、Java命令、环境变量及目... 目录方法 1:通过update-alternatives查询(推荐)方法 2:检查所有已安装的 JDK方

Linux系统之lvcreate命令使用解读

《Linux系统之lvcreate命令使用解读》lvcreate是LVM中创建逻辑卷的核心命令,支持线性、条带化、RAID、镜像、快照、瘦池和缓存池等多种类型,实现灵活存储资源管理,需注意空间分配、R... 目录lvcreate命令详解一、命令概述二、语法格式三、核心功能四、选项详解五、使用示例1. 创建逻

Python Web框架Flask、Streamlit、FastAPI示例详解

《PythonWeb框架Flask、Streamlit、FastAPI示例详解》本文对比分析了Flask、Streamlit和FastAPI三大PythonWeb框架:Flask轻量灵活适合传统应用... 目录概述Flask详解Flask简介安装和基础配置核心概念路由和视图模板系统数据库集成实际示例Stre

Olingo分析和实践之OData框架核心组件初始化(关键步骤)

《Olingo分析和实践之OData框架核心组件初始化(关键步骤)》ODataSpringBootService通过初始化OData实例和服务元数据,构建框架核心能力与数据模型结构,实现序列化、URI... 目录概述第一步:OData实例创建1.1 OData.newInstance() 详细分析1.1.1

RabbitMQ消息总线方式刷新配置服务全过程

《RabbitMQ消息总线方式刷新配置服务全过程》SpringCloudBus通过消息总线与MQ实现微服务配置统一刷新,结合GitWebhooks自动触发更新,避免手动重启,提升效率与可靠性,适用于配... 目录前言介绍环境准备代码示例测试验证总结前言介绍在微服务架构中,为了更方便的向微服务实例广播消息,

使用Python构建一个高效的日志处理系统

《使用Python构建一个高效的日志处理系统》这篇文章主要为大家详细讲解了如何使用Python开发一个专业的日志分析工具,能够自动化处理、分析和可视化各类日志文件,大幅提升运维效率,需要的可以了解下... 目录环境准备工具功能概述完整代码实现代码深度解析1. 类设计与初始化2. 日志解析核心逻辑3. 文件处

golang程序打包成脚本部署到Linux系统方式

《golang程序打包成脚本部署到Linux系统方式》Golang程序通过本地编译(设置GOOS为linux生成无后缀二进制文件),上传至Linux服务器后赋权执行,使用nohup命令实现后台运行,完... 目录本地编译golang程序上传Golang二进制文件到linux服务器总结本地编译Golang程序

Linux系统性能检测命令详解

《Linux系统性能检测命令详解》本文介绍了Linux系统常用的监控命令(如top、vmstat、iostat、htop等)及其参数功能,涵盖进程状态、内存使用、磁盘I/O、系统负载等多维度资源监控,... 目录toppsuptimevmstatIOStatiotopslabtophtopdstatnmon

Spring 框架之Springfox使用详解

《Spring框架之Springfox使用详解》Springfox是Spring框架的API文档工具,集成Swagger规范,自动生成文档并支持多语言/版本,模块化设计便于扩展,但存在版本兼容性、性... 目录核心功能工作原理模块化设计使用示例注意事项优缺点优点缺点总结适用场景建议总结Springfox 是

java向微信服务号发送消息的完整步骤实例

《java向微信服务号发送消息的完整步骤实例》:本文主要介绍java向微信服务号发送消息的相关资料,包括申请测试号获取appID/appsecret、关注公众号获取openID、配置消息模板及代码... 目录步骤1. 申请测试系统2. 公众号账号信息3. 关注测试号二维码4. 消息模板接口5. Java测试