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 RtuDownConstantTask extends CoreTask { 
 | 
    private static final Logger log = LogManager.getLogger(RtuDownConstantTask.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); 
 | 
            } 
 | 
        } 
 | 
    } 
 | 
  
 | 
  
 | 
} 
 |