package com.dy.rtuMw.server.tasks; import com.dy.common.mw.core.CoreTask; import com.dy.common.queue.Node; import com.dy.rtuMw.server.mqtt.MqttPubMsgCache; import com.dy.rtuMw.server.mqtt.MqttPubMsgNode; import org.apache.logging.log4j.LogManager; import org.apache.logging.log4j.Logger; /** * @Author: liurunyu * @Date: 2025/6/4 16:25 * @Description */ public class MqttPubMessageConstantTask extends CoreTask { private static final Logger log = LogManager.getLogger(MqttPubMessageConstantTask.class.getName()); /** * 在单线程环境中运行 */ @Override public Integer execute() { try{ dealMqMsg() ; }catch(Exception e){ log.error(e); } return MqttPubMsgCache.size()>0?0:1 ; } /** * 处理MQTT订阅的消息 */ public void dealMqMsg() { Node first = MqttPubMsgCache.getFirstQueueNode() ; if(first != null){ Node last = MqttPubMsgCache.getLastQueueNode() ; while (last != null){ last = this.doDealMqMsg(System.currentTimeMillis(), first, last); } } } /** * 处理缓存的上行数据节点 * @param now 当前时刻 * @param first 第一个节点 * @param last 最后一个节点 */ private Node doDealMqMsg(Long now, Node first, Node last){ if(last != null){ //在dealNode方法中,可能要把last从队列中移除,这时last.pre为空,所以提前把last.pre取出来 Node pre = last.pre ; dealNode(now, last) ; if(first != last){ return pre ; }else{ //停止 return null ; } }else{ return null ; } } /** * 处理一个节点 * @param now 现在时刻 * @param node 节点 */ private void dealNode(Long now, Node node){ if(node != null && node.obj != null){ MqttPubMsgNode obj = (MqttPubMsgNode)node.obj ; boolean removeNode = obj.dealSelf(now) ; if(removeNode){ MqttPubMsgCache.removeNode(node); } } } }