From 9f05696822f8feee385a34a92dd9aa16009e84a0 Mon Sep 17 00:00:00 2001 From: Junjie <fallin.jie@qq.com> Date: 星期日, 18 六月 2023 12:38:00 +0800 Subject: [PATCH] 寻路算法,地图节点优化,剔除原入出库模式获取地图节点方案,改为根据库位状态实时获取节点信息或直接获取无过滤的完整节点信息 --- src/main/java/com/zy/core/thread/BarcodeThread.java | 47 +++++++++++++++++++++++++++++------------------ 1 files changed, 29 insertions(+), 18 deletions(-) diff --git a/src/main/java/com/zy/core/thread/BarcodeThread.java b/src/main/java/com/zy/core/thread/BarcodeThread.java index 6c4a7eb..39bed10 100644 --- a/src/main/java/com/zy/core/thread/BarcodeThread.java +++ b/src/main/java/com/zy/core/thread/BarcodeThread.java @@ -1,12 +1,16 @@ package com.zy.core.thread; +import com.alibaba.fastjson.JSONObject; +import com.core.common.Cools; +import com.core.common.DateUtils; +import com.zy.core.News; import com.zy.core.Slave; import com.zy.core.ThreadHandler; -import com.zy.core.cache.MessageQueue; -import com.zy.core.enums.SlaveType; -import com.zy.core.model.Task; +import com.zy.core.cache.OutputQueue; import lombok.Data; import lombok.extern.slf4j.Slf4j; + +import java.util.Date; /** * 鏉$爜鎵弿浠嚎绋� @@ -17,32 +21,33 @@ public class BarcodeThread implements Runnable, ThreadHandler { private Slave slave; + private StringBuffer barcode = new StringBuffer(); public BarcodeThread(Slave slave) { this.slave = slave; - connect(); } - @Override - @SuppressWarnings("InfiniteLoopStatement") - public void run() { - while (true) { - try { - Task task = MessageQueue.poll(SlaveType.Barcode, slave.getId()); - if (task != null) { - System.out.println("浠诲姟"+task.getId()); - } - Thread.sleep(3000); - } catch (Exception e) { - e.printStackTrace(); - } + public String getBarcode() { + return barcode.toString(); + } + public void setBarcode(String barcode) { + this.barcode.delete(0, this.barcode.length()); + this.barcode.append(barcode); + if(!Cools.isEmpty(barcode)) { + News.info("{}鍙锋潯鐮佸櫒锛屾绱㈡暟鎹細{}", slave.getId(), this.barcode); + JSONObject jsonObject = new JSONObject(); + jsonObject.put("time", DateUtils.convert(new Date(), DateUtils.yyyyMMddHHmmss_F)); + jsonObject.put("barcode", barcode); + if (OutputQueue.BARCODE.size() >= 32) { + OutputQueue.BARCODE.poll(); + } + OutputQueue.BARCODE.offer(jsonObject); } } @Override public boolean connect() { - return false; } @@ -50,4 +55,10 @@ public void close() { } + + @Override + public void run() { + + } + } -- Gitblit v1.9.1