From bc0a69ea4a4fb49dadc02bf548d8f3fd3f60d18a Mon Sep 17 00:00:00 2001 From: luxiaotao1123 <t1341870251@163.com> Date: 星期三, 19 八月 2020 09:22:09 +0800 Subject: [PATCH] # --- src/main/java/com/zy/core/thread/BarcodeThread.java | 32 +++++++++++++++++++------------- 1 files changed, 19 insertions(+), 13 deletions(-) diff --git a/src/main/java/com/zy/core/thread/BarcodeThread.java b/src/main/java/com/zy/core/thread/BarcodeThread.java index 6fd0da4..2380348 100644 --- a/src/main/java/com/zy/core/thread/BarcodeThread.java +++ b/src/main/java/com/zy/core/thread/BarcodeThread.java @@ -1,6 +1,5 @@ package com.zy.core.thread; -import HslCommunication.BasicFramework.SoftBasic; import com.zy.core.Slave; import com.zy.core.ThreadHandler; import lombok.Data; @@ -29,21 +28,23 @@ public BarcodeThread(Slave slave) { this.slave = slave; - connect(); } @Override @SuppressWarnings("InfiniteLoopStatement") public void run() { + connect(); while (true) { try { -// Task task = MessageQueue.poll(SlaveType.Barcode, slave.getId()); - barcode = "10001136"; - Thread.sleep(3000); + write("T".getBytes(), "T".length()); + byte[] read = read(11, 1000); + if (null != read) { + barcode = new String(read); + } + Thread.sleep(1000); } catch (Exception e) { e.printStackTrace(); } - } } @@ -53,7 +54,7 @@ close(); //1.涓诲姩閲婃斁杩炴帴 //2.鏌愪簺鏈嶅姟鍣ㄥ鎸囧畾ip鏈夐摼璺暟闄愬埗 socket = new Socket(); //socket.setKeepAlive(true); - SocketAddress socketAddress = new InetSocketAddress("192.168.2.150", 51236); + SocketAddress socketAddress = new InetSocketAddress(slave.getIp(), slave.getPort()); socket.connect(socketAddress, 1000); //鏌愪簺鏈嶅姟鍣╬ing寤惰繜楂樻椂瑕佸鍔�,鍚﹀垯浼氭姤閿檆onnect timeout dataOutputStream = new DataOutputStream(socket.getOutputStream()); dataInputStream = new DataInputStream(socket.getInputStream()); @@ -86,13 +87,17 @@ } public void write(byte[] msg, int len) throws IOException { - log.trace("dataOutputStream.write"); - dataOutputStream.write(msg, 0, len); - log.trace("dataOutputStream.flush"); - dataOutputStream.flush(); + if (null != dataInputStream) + { + dataOutputStream.write(msg, 0, len); + dataOutputStream.flush(); + } } public byte[] read(int bufferSize, int timeOut) throws IOException { + if (socket == null) { + return null; + } socket.setSoTimeout(timeOut * 1000); byte[] bytes = new byte[bufferSize]; log.trace("dataInputStream.read"); @@ -123,12 +128,13 @@ } public static void main(String[] args) throws Exception { - BarcodeThread barcodeThread = new BarcodeThread(); + BarcodeThread barcodeThread = new BarcodeThread(new Slave()); + barcodeThread.getSlave().setIp("192.168.2.150"); + barcodeThread.getSlave().setPort(51236); boolean connect = barcodeThread.connect(); System.out.println(connect); barcodeThread.write("T".getBytes(), "T".length()); byte[] read = barcodeThread.read(11, 1000); - System.out.println(SoftBasic.ByteToHexString(read)); System.out.println(new String(read)); } } -- Gitblit v1.9.1