|  |  | 
 |  |  |             log.error("堆垛机写入命令为空"); | 
 |  |  |             return false; | 
 |  |  |         } | 
 |  |  |         try{ | 
 |  |  |             OperateResultExOne<byte[]> resultRead = siemensNet.Read("DB100.0", (short) 24); | 
 |  |  |             if (resultRead.IsSuccess) { | 
 |  |  |                 CrnCommand one = new CrnCommand(); | 
 |  |  |                 one.setTaskNo(siemensNet.getByteTransform().TransInt16(resultRead.Content, 2)); | 
 |  |  |                 one.setTaskMode(siemensNet.getByteTransform().TransInt16(resultRead.Content, 4)); | 
 |  |  |                 one.setSourcePosX(siemensNet.getByteTransform().TransInt16(resultRead.Content, 6)); | 
 |  |  |                 one.setSourcePosY(siemensNet.getByteTransform().TransInt16(resultRead.Content, 8)); | 
 |  |  |                 one.setSourcePosZ(siemensNet.getByteTransform().TransInt16(resultRead.Content, 10)); | 
 |  |  |                 one.setDestinationPosX(siemensNet.getByteTransform().TransInt16(resultRead.Content, 12)); | 
 |  |  |                 one.setDestinationPosY(siemensNet.getByteTransform().TransInt16(resultRead.Content, 14)); | 
 |  |  |                 one.setDestinationPosZ(siemensNet.getByteTransform().TransInt16(resultRead.Content, 16)); | 
 |  |  |                 if (!command.getTaskNo().equals(one.getTaskNo()) || !command.getTaskMode().equals(one.getTaskMode()) | 
 |  |  |                         || !command.getSourcePosX().equals(one.getSourcePosX()) || !command.getSourcePosY().equals(one.getSourcePosY()) | 
 |  |  |                         || !command.getSourcePosZ().equals(one.getSourcePosZ()) || !command.getDestinationPosX().equals(one.getDestinationPosX()) | 
 |  |  |                         || !command.getDestinationPosY().equals(one.getDestinationPosY()) || !command.getDestinationPosZ().equals(one.getDestinationPosZ()) | 
 |  |  |                 ){ | 
 |  |  |                     log.error("下发前:[id:{}] >>>>> 写入[{}],===>>回读[{}]", slave.getId(), JSON.toJSON(command),JSON.toJSON(one)); | 
 |  |  |                 } else { | 
 |  |  |                     log.info("下发前:[id:{}] >>>>> 写入[{}],===>>回读[{}]", slave.getId(), JSON.toJSON(command),JSON.toJSON(one)); | 
 |  |  |                 } | 
 |  |  |             } | 
 |  |  |         }catch (Exception e){ | 
 |  |  |             log.error("堆垛机命令地址写入后回读出错"); | 
 |  |  |         } | 
 |  |  | //        convertRow(command); | 
 |  |  |         command.setCrnNo(slave.getId()); | 
 |  |  |         short[] array = new short[10]; | 
 |  |  | 
 |  |  | //        array[10] = command.getDestinationStaNo(); | 
 |  |  |         array[9] = command.getCommand(); | 
 |  |  |         OperateResult result = siemensNet.Write("DB100.0", array); | 
 |  |  |         log.info("堆垛机命令下发[id:{}] >>>>> {}", slave.getId(), array); | 
 |  |  |  | 
 |  |  |         if (command.getAckFinish() == 0) { | 
 |  |  |             short commandFinish = 1; | 
 |  |  |             Thread.sleep(100L); | 
 |  |  |             result = siemensNet.Write("DB100.18", commandFinish); | 
 |  |  |         if(!result.IsSuccess){ | 
 |  |  |             log.error("写入堆垛机plc数据失败,重新添加任务到队列 ===>> [id:{}],{}", slave.getId(), JSON.toJSON(command)); | 
 |  |  |             MessageQueue.offer(SlaveType.Crn, slave.getId(), new Task(2, command)); | 
 |  |  |             Thread.sleep(100); | 
 |  |  |             readStatus(); | 
 |  |  |             return false; | 
 |  |  |         } | 
 |  |  |         //堆垛机任务写入后,回读一次,看是否成功 | 
 |  |  |         Thread.sleep(200); | 
 |  |  |         try{ | 
 |  |  |             OperateResultExOne<byte[]> resultRead = siemensNet.Read("DB100.0", (short) 18); | 
 |  |  |             if (resultRead.IsSuccess) { | 
 |  |  |                 CrnCommand one = new CrnCommand(); | 
 |  |  |                 one.setTaskNo(siemensNet.getByteTransform().TransInt16(resultRead.Content, 2)); | 
 |  |  |                 one.setTaskMode(siemensNet.getByteTransform().TransInt16(resultRead.Content, 4)); | 
 |  |  |                 one.setSourcePosX(siemensNet.getByteTransform().TransInt16(resultRead.Content, 6)); | 
 |  |  |                 one.setSourcePosY(siemensNet.getByteTransform().TransInt16(resultRead.Content, 8)); | 
 |  |  |                 one.setSourcePosZ(siemensNet.getByteTransform().TransInt16(resultRead.Content, 10)); | 
 |  |  |                 one.setDestinationPosX(siemensNet.getByteTransform().TransInt16(resultRead.Content, 12)); | 
 |  |  |                 one.setDestinationPosY(siemensNet.getByteTransform().TransInt16(resultRead.Content, 14)); | 
 |  |  |                 one.setDestinationPosZ(siemensNet.getByteTransform().TransInt16(resultRead.Content, 16)); | 
 |  |  |                 if (!command.getTaskNo().equals(one.getTaskNo()) || !command.getTaskMode().equals(one.getTaskMode()) | 
 |  |  |                         || !command.getSourcePosX().equals(one.getSourcePosX()) || !command.getSourcePosY().equals(one.getSourcePosY()) | 
 |  |  |                         || !command.getSourcePosZ().equals(one.getSourcePosZ()) || !command.getDestinationPosX().equals(one.getDestinationPosX()) | 
 |  |  |                         || !command.getDestinationPosY().equals(one.getDestinationPosY()) || !command.getDestinationPosZ().equals(one.getDestinationPosZ()) | 
 |  |  |                 ){ | 
 |  |  |                     try{ | 
 |  |  |                         log.error("堆垛机命令地址写入后回读失败[id:{}] >>>>> 写入[{}],===>>回读[{}]", slave.getId(), JSON.toJSON(command),JSON.toJSON(one)); | 
 |  |  |                     }catch (Exception e){ | 
 |  |  |                         try{ | 
 |  |  |                             log.error("日志打印失败:===>>参数one报错 [id:{}],{}", slave.getId(), JSON.toJSON(command),JSON.toJSON(resultRead)); | 
 |  |  |                         }catch (Exception e1){ | 
 |  |  |                             log.error("日志打印失败:===>> [id:{}],{}", slave.getId(), JSON.toJSON(command)); | 
 |  |  |                         } | 
 |  |  |                     } | 
 |  |  |                     log.error("堆垛机命令回读失败后,重新添加任务到队列 ===>> [id:{}],{}", slave.getId(), JSON.toJSON(command)); | 
 |  |  |                     MessageQueue.offer(SlaveType.Crn, slave.getId(), new Task(2, command)); | 
 |  |  |                     Thread.sleep(100); | 
 |  |  |                     readStatus(); | 
 |  |  |                     return false; | 
 |  |  |                 } else { | 
 |  |  |                     log.info("堆垛机命令地址写入后回读成功[id:{}] >>>>> 写入[{}],===>>回读[{}]", slave.getId(), JSON.toJSON(command),JSON.toJSON(one)); | 
 |  |  |                 } | 
 |  |  |             } | 
 |  |  |         }catch (Exception e){ | 
 |  |  |             log.error("堆垛机命令地址写入后回读出错"); | 
 |  |  |         } | 
 |  |  |         if (command.getAckFinish() == 0) { | 
 |  |  |             if (result.IsSuccess) { | 
 |  |  |                 Thread.sleep(300); | 
 |  |  |                 //任务下发次数 | 
 |  |  |                 int writeCount2 = 0; | 
 |  |  |  | 
 |  |  |                 do { | 
 |  |  |                     writeCount2++; | 
 |  |  |                     short commandFinish = (short) 1; | 
 |  |  |                     result = siemensNet.Write("DB100.18", commandFinish); | 
 |  |  |                     if(result.IsSuccess){ | 
 |  |  |                         //堆垛机任务写入后,回读一次,看是否成功 | 
 |  |  |                         Thread.sleep(200); | 
 |  |  |                         OperateResultExOne<byte[]> resultRead = siemensNet.Read("DB100.18", (short) 2); | 
 |  |  |                         if (resultRead.IsSuccess) { | 
 |  |  |                             commandFinish=siemensNet.getByteTransform().TransInt16(resultRead.Content, 0); | 
 |  |  |                             if (commandFinish != 1){ | 
 |  |  |                                 log.error("堆垛机任务确认位"+commandFinish+"写入数据与回读数据不一致!"+"循环执行次数:"+writeCount2+"次"); | 
 |  |  |                             }else{ | 
 |  |  |                                 //任务命令写入成功 | 
 |  |  |                                 log.info("堆垛机任务确认位"+commandFinish+"回读成功!"+"循环执行次数:"+writeCount2+"次"); | 
 |  |  |                                 break; | 
 |  |  |                             } | 
 |  |  |                         }else { | 
 |  |  |                             log.error("堆垛机任务确认位"+commandFinish+"回读失败!"+"循环执行次数:"+writeCount2+"次"); | 
 |  |  |                         } | 
 |  |  |                     } else { | 
 |  |  |                         log.error("堆垛机任务确认位"+commandFinish+"写入失败!"+"循环执行次数:"+writeCount2+"次"); | 
 |  |  |                     } | 
 |  |  |                 }while (writeCount2<5); | 
 |  |  |             } | 
 |  |  |         } | 
 |  |  |         //if (command.getAckFinish() == 0) { | 
 |  |  |         //    short commandFinish = 1; | 
 |  |  |         //    Thread.sleep(100L); | 
 |  |  |         //    result = siemensNet.Write("DB100.18", commandFinish); | 
 |  |  |         //} | 
 |  |  |  | 
 |  |  |         try { | 
 |  |  |             // 日志记录 |