当前位置: 首页 > news >正文

tigase源码学习杂记-AbstractMessageReceiver

前言

废话,最近把工作中用的基于XMPP协议的经典开源框架又读了一遍,整理一下其优秀的源码学习记录。

概述

AbstractMessageReceiver是tigase核心组件MessageRouter、SessionManager的抽象父类,是tigase消息接收器的抽象。AbstractMessageReceiver使用的是模板的设计模式。对消息接收的基础封装。

类图整体框架分析

类图

抽象接收器主要的实现的核心接口是MessageReceiver接口,该接口定义了接收消息的主要的接口,MesageReceiver接口的核心就是管理路由RegexRouting和往队列中添加数据包操作(addPacket)。AbstractMessageReceiver类实现了接口的所有方法,并向子类提供一个processPacket(Packet)方法进行自定义实现。所以MessageRouter和SessionManger都是重写processPacket(Packet)实现对接受到的消息进行自定义的处理。

其他的接口和类的简介:

  • BasicComponent:全局组件化类的定义实现,tigase官方的全局组件化和可扩展都是基于这个类的实现。后面专门会有一篇文章进行介绍。
  • PacketWriterWithTimeout:相应带超时时间的一个接口定义
  • StatisticsContainer: 统计接口的定义,不是核心,暂时不作为学习的重点

核心数据结构及线程模型分析

基本数据结构介绍

数据和线程模型主要是基于四个成员变量out_queues、in_queues、threadsQueueIn、threadsQueueOut 围绕进行的。其中out_queues、in_queues两个成员变量是两个处理Packet的优先级队列的列表。threadsQueueIn、threadsQueueOut是两个QueueListener的双向队列,QueueListener由上面的类可知,是一个包含可以处理Packet的优先级队列线程的内部类,作用是对出入队消息进行监听和处理。

内部线程数据处理模型

内部线程数据处理模型是一个线程对应一个优先级队列进行数据的处理。线程监听到数据对列中有数据就去take(),take()之后根据消息类是IN_QUEUE还是OUT_QUEUE进行不同数据包的处理。线程数据处理模型如下图所示。

线程数据处理模型图

那么线程模型和队列是如何绑定起来的呢?我们通过初始化的源代码进行分析一下。源码如下所示:

    /*** 开启线程,初始化QueueListener监听线程,绑定线程和对列*/private void startThreads() {...//入队(接收)线程(双向对列)为空,初始化操作if (threadsQueueIn == null) {threadsQueueIn = new ArrayDeque<>(8);//创建指定入队线程,默认是1for (int i = 0; i < in_queues_size; i++) {QueueListener in_thread = new QueueListener(in_queues.get(i), QueueType.IN_QUEUE);in_thread.setName("in_" + i + "-" + getName());in_thread.start();threadsQueueIn.add(in_thread);}}//出队(转发)线程(双向对列)为空,初始化操作if (threadsQueueOut == null) {//创建指定出队的线程,默认是1threadsQueueOut = new ArrayDeque<>(8);for (int i = 0; i < out_queues_size; i++) {QueueListener out_thread = new QueueListener(out_queues.get(i), QueueType.OUT_QUEUE);out_thread.setName("out_" + i + "-" + getName());out_thread.start();threadsQueueOut.add(out_thread);}}    ...
}

以上代码是接受器启动调用的核心代码(其中省略了一些日志打印和监听相关的非核心代码),核心就是根据优先级队列进行循环遍历,创建对应的监听器,并设置优先级队列给对应的优先级队列。

小结

AbstractMessageReceiver对象是消息接收器的核心实现,模版的设计模式有利于代码的复用,公共代码的抽象,1对1的线程队列数据处理模型充分利用多线程的优势,并发的处理数据,优先级队列保证了数据处理的顺序性。

相关文章:

  • 二级评论列表-Java实现
  • PyTorch深度学习框架60天进阶学习计划 - 第46天:自动化模型设计(二)
  • 实战设计模式之备忘录模式
  • 数量关系 多级数列1
  • ClawCloud的免费空间(github用户登录可以获得$5元/月的免费额度)
  • PostgreSQL 的pgloader 工具介绍
  • Qt C++ 解析和处理 XML 文件示例
  • django基于爬虫的网络新闻分析系统的设计与实现(源码+lw+部署文档+讲解),源码可白嫖!
  • 数据驱动未来:大数据在智能网联汽车中的深度应用
  • 2.凸包优化求解
  • 突破速率瓶颈:毫米波技术如何推动 5G 网络迈向极限?
  • 【刷题Day20】TCP和UDP
  • 在STM32的定时器外设中,选择使用哪个外部时钟配置函数
  • 【C++算法】65.栈_删除字符中的所有相邻重复项
  • MOPSO实现无人机多目标路径规划(Matlab完整源码和数据)
  • package.json ^、~、>、>=、* 详解
  • 【java实现+4种变体完整例子】排序算法中【计数排序】的详细解析,包含基础实现、常见变体的完整代码示例,以及各变体的对比表格
  • 【大模型】 LangChain框架 -LangChain用例
  • [matlab]南海地形眩晕图代码
  • Spring Boot + Caffeine:打造高性能缓存解决方案
  • 五一假期出行预订进入高潮:酒店搜索热度翻倍,“请4休11”拼假带动长线游
  • 95后男中音胡斯豪敲开芝加哥抒情歌剧院大门
  • 为博眼球竟编造一女孩被活埋,公安机关公布10起谣言案件
  • 观察|美军在菲律宾部署新导弹,试图继续构建“导弹链”
  • 秦洪看盘|A股缩量窄幅震荡,短线或延续有韧性、无弹性走势
  • 中华人民共和国和柬埔寨王国关于构建新时代全天候中柬命运共同体、落实三大全球倡议的联合声明