我正在尝试使用此代码从设备接收字符串:
byte[] buf = new byte[4];
int read = inFromDevice.read(buf);
Logger.getLogger(Utill.class.getName() + " DEBUG_ERR01").log(Level.INFO, "Bytes read: {0}", read);
int msgLength = ByteBuffer.wrap(buf).getInt();
Logger.getLogger(Utill.class.getName() + " DEBUG_ERR01").log(Level.INFO, "Message length: {0}", msgLength);
Reader r = new InputStreamReader(inFromDevice);
char[] cb = new char[msgLength];
int actualCharsRead = r.read(cb);
Logger.getLogger(Utill.class.getName() + " DEBUG_ERR01").log(Level.INFO, "Actual chars read: {0} char array length: {1}", new Object[]{actualCharsRead, cb.length});
String msgText = String.valueOf(cb, 0, cb.length);
Logger.getLogger(Utill.class.getName() + "Messages Loggining recieve: ").log(Level.INFO, msgText);
return msgText;
从设备中和输入流从接受的服务器插槽中获取。
代码大部分时间都在工作并返回消息,但有时我收到的消息小于msgLength(根据协议是错误的)
日志中的一个示例是Actual chars read: 1020 char array length: 1391
我认为由于网络问题或设备出现问题,问题是外部的,但我需要一些专家见解。Java中是否有任何已知问题可能导致这种情况?
呼啦一阵风
相关分类