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

相关文章

Java深度学习库DJL实现Python的NumPy方式

《Java深度学习库DJL实现Python的NumPy方式》本文介绍了DJL库的背景和基本功能,包括NDArray的创建、数学运算、数据获取和设置等,同时,还展示了如何使用NDArray进行数据预处理... 目录1 NDArray 的背景介绍1.1 架构2 JavaDJL使用2.1 安装DJL2.2 基本操

在不同系统间迁移Python程序的方法与教程

《在不同系统间迁移Python程序的方法与教程》本文介绍了几种将Windows上编写的Python程序迁移到Linux服务器上的方法,包括使用虚拟环境和依赖冻结、容器化技术(如Docker)、使用An... 目录使用虚拟环境和依赖冻结1. 创建虚拟环境2. 冻结依赖使用容器化技术(如 docker)1. 创

修改若依框架Token的过期时间问题

《修改若依框架Token的过期时间问题》本文介绍了如何修改若依框架中Token的过期时间,通过修改`application.yml`文件中的配置来实现,默认单位为分钟,希望此经验对大家有所帮助,也欢迎... 目录修改若依框架Token的过期时间修改Token的过期时间关闭Token的过期时js间总结修改若依

CentOS系统Maven安装教程分享

《CentOS系统Maven安装教程分享》本文介绍了如何在CentOS系统中安装Maven,并提供了一个简单的实际应用案例,安装Maven需要先安装Java和设置环境变量,Maven可以自动管理项目的... 目录准备工作下载并安装Maven常见问题及解决方法实际应用案例总结Maven是一个流行的项目管理工具

解读Redis秒杀优化方案(阻塞队列+基于Stream流的消息队列)

《解读Redis秒杀优化方案(阻塞队列+基于Stream流的消息队列)》该文章介绍了使用Redis的阻塞队列和Stream流的消息队列来优化秒杀系统的方案,通过将秒杀流程拆分为两条流水线,使用Redi... 目录Redis秒杀优化方案(阻塞队列+Stream流的消息队列)什么是消息队列?消费者组的工作方式每

使用C/C++调用libcurl调试消息的方式

《使用C/C++调用libcurl调试消息的方式》在使用C/C++调用libcurl进行HTTP请求时,有时我们需要查看请求的/应答消息的内容(包括请求头和请求体)以方便调试,libcurl提供了多种... 目录1. libcurl 调试工具简介2. 输出请求消息使用 CURLOPT_VERBOSE使用 C

C#实现系统信息监控与获取功能

《C#实现系统信息监控与获取功能》在C#开发的众多应用场景中,获取系统信息以及监控用户操作有着广泛的用途,比如在系统性能优化工具中,需要实时读取CPU、GPU资源信息,本文将详细介绍如何使用C#来实现... 目录前言一、C# 监控键盘1. 原理与实现思路2. 代码实现二、读取 CPU、GPU 资源信息1.

Java中Springboot集成Kafka实现消息发送和接收功能

《Java中Springboot集成Kafka实现消息发送和接收功能》Kafka是一个高吞吐量的分布式发布-订阅消息系统,主要用于处理大规模数据流,它由生产者、消费者、主题、分区和代理等组件构成,Ka... 目录一、Kafka 简介二、Kafka 功能三、POM依赖四、配置文件五、生产者六、消费者一、Kaf

在C#中获取端口号与系统信息的高效实践

《在C#中获取端口号与系统信息的高效实践》在现代软件开发中,尤其是系统管理、运维、监控和性能优化等场景中,了解计算机硬件和网络的状态至关重要,C#作为一种广泛应用的编程语言,提供了丰富的API来帮助开... 目录引言1. 获取端口号信息1.1 获取活动的 TCP 和 UDP 连接说明:应用场景:2. 获取硬

JAVA系统中Spring Boot应用程序的配置文件application.yml使用详解

《JAVA系统中SpringBoot应用程序的配置文件application.yml使用详解》:本文主要介绍JAVA系统中SpringBoot应用程序的配置文件application.yml的... 目录文件路径文件内容解释1. Server 配置2. Spring 配置3. Logging 配置4. Ma