package com.dy.rtuMw.server.tasks; import org.apache.logging.log4j.LogManager; import org.apache.logging.log4j.Logger; import com.dy.common.queue.Node; import com.dy.common.mw.core.CoreTask; import com.dy.rtuMw.server.forTcp.TcpDownCommandCache; import com.dy.rtuMw.server.forTcp.TcpDownCommandObj; import com.dy.rtuMw.server.forTcp.TcpSessionCache; /** * 处理RTU下行命令数据的恒久任务 */ public class ToRtuConstantTask extends CoreTask { private static final Logger log = LogManager.getLogger(ToRtuConstantTask.class.getName()); /** * 在单线程环境中运行 */ @Override public Integer execute() { try{ dealTcpSession() ; }catch(Exception e){ log.error("更新RTU会话上报数据时刻时发生集合操作异常,此异常并不影响系统正常运行", e); } try{ //log.info("当前下行命令队列中还有结点数量:" + TcpDownCommandCache.size()); dealDownCom() ; }catch(Exception e){ log.error(e); } return TcpDownCommandCache.size()>0?0:1 ; } /** * 处理TCP缓存中的各个TCP Session的上行数据时刻 */ private void dealTcpSession(){ TcpSessionCache.updateRtuStatus(System.currentTimeMillis() ) ; } /** * 处理下行命令 */ public void dealDownCom() { Node first = TcpDownCommandCache.getFirstQueueNode() ; if(first != null){ Node last = TcpDownCommandCache.getLastQueueNode() ; while (last != null){ last = this.doDealDownComm(System.currentTimeMillis(), first, last); } } } /** * 处理缓存的下行命令节点 * @param now 当前时刻 * @param first 第一个节点 * @param last 最后一个节点 */ private Node doDealDownComm(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 ; } } //////////////////////////////////////////////// // //以下实现,采用了递归调用,当队列缓存结点很多时,会产生栈溢出异常 // //////////////////////////////////////////////// /** * 处理下行命令 public Integer dealDownCommand(Long now) { Node first = TcpDownCommandCache.getFirstQueueNode() ; if(first != null){ Integer count = TcpDownCommandCache.size() ; Node last = TcpDownCommandCache.getLastQueueNode() ; this.doDealDownCommand(now, first, last); return count ; } return null ; } */ /** * 处理缓存的下行命令节点 * @param now 当前时刻 * @param first 第一个节点 * @param last 最后一个节点 private void doDealDownCommand1(Long now, Node first, Node last){ if(first != null){ //在dealNode方法中,可能要把first从队列中移除,这时first.next为空,所以提前把first.next取出来 Node next = first.next ; dealNode(now, first) ; if(last != null && first != last){ doDealDownCommand(now, next, last) ; }else if(last != null && first == last){ //停止 }else if(last == null){ //这种情况不会存在 doDealDownCommand(now, next, last) ; } } } */ /** * 处理缓存的下行命令节点 * @param now 当前时刻 * @param first 第一个节点 * @param last 最后一个节点 private void doDealDownCommand(Long now, Node first, Node last){ if(last != null){ //在dealNode方法中,可能要把last从队列中移除,这时last.pre为空,所以提前把last.pre取出来 Node pre = last.pre ; dealNode(now, last) ; if(first != null && first != last){ doDealDownCommand(now, first, pre) ; }else if(first != null && first == last){ //停止 }else if(first == null){ //这种情况不会存在 doDealDownCommand(now, null, pre) ; } } } */ /** * 处理一个节点 * @param now 现在时刻 * @param node 节点 */ private void dealNode(Long now, Node node){ if(node != null && node.obj != null){ TcpDownCommandObj obj = (TcpDownCommandObj)node.obj ; boolean removeNode = obj.dealSelf(now) ; if(removeNode){ TcpDownCommandCache.removeNode(node); } } } }