我成功安装并测试了Java Comm API。 我可以通过串口发送和接收数据。 但问题是,每个角色前面还有19个空格。 当我尝试使用超级终端时,额外的空间不存在。
例如:
+ CENG:0 “0021,37,99,404,46,36,0000,05,05,77,255”
预计。但是Java程序在每个charector之前用空格输出它
+ E N
代码是:
import java.io.*;
import java.util.*;
import javax.comm.*;
public class SimpleRead implements Runnable, SerialPortEventListener
{
static CommPortIdentifier portId;
static Enumeration portList;
InputStream inputStream;
SerialPort serialPort;
Thread readThread;
public static void main(String[] args) throws Exception
{
portList = CommPortIdentifier.getPortIdentifiers();
System.out.println("SimpleRead Started.");
while (portList.hasMoreElements())
{
portId = (CommPortIdentifier) portList.nextElement();
if (portId.getPortType() == CommPortIdentifier.PORT_SERIAL)
{
System.out.println ("Found " + portId.getName());
if (portId.getName().equals("COM5"))
{
OutputStream outputStream;
SerialPort writePort = (SerialPort) portId.open("SimpleWriteApp", 2000);
writePort.setSerialPortParams(2400,
SerialPort.DATABITS_8,
SerialPort.STOPBITS_1,
SerialPort.PARITY_NONE);
outputStream = writePort.getOutputStream();
outputStream.write("AT+CENG=2".getBytes());
writePort.close();
SimpleRead reader = new SimpleRead();
}
}
}
}
public SimpleRead()
{
try
{
serialPort = (SerialPort) portId.open("SimpleReadApp", 2000);
}
catch (PortInUseException e)
{
e.printStackTrace();
}
try
{
inputStream = serialPort.getInputStream();
}
catch (IOException e)
{
e.printStackTrace();
}
try
{
serialPort.addEventListener(this);
}
catch (TooManyListenersException e)
{
e.printStackTrace();
}
serialPort.notifyOnDataAvailable(true);
try
{
serialPort.setSerialPortParams(2400, SerialPort.DATABITS_8,
SerialPort.STOPBITS_1, SerialPort.PARITY_NONE);
}
catch (UnsupportedCommOperationException e)
{
e.printStackTrace();
}
readThread = new Thread(this);
readThread.start();
}
public void run()
{
try
{
Thread.sleep(20000);
}
catch (InterruptedException e)
{
e.printStackTrace();
}
}
public void serialEvent(SerialPortEvent event)
{
switch (event.getEventType())
{
case SerialPortEvent.BI:
case SerialPortEvent.OE:
case SerialPortEvent.FE:
case SerialPortEvent.PE:
case SerialPortEvent.CD:
case SerialPortEvent.CTS:
case SerialPortEvent.DSR:
case SerialPortEvent.RI:
case SerialPortEvent.OUTPUT_BUFFER_EMPTY:
break;
case SerialPortEvent.DATA_AVAILABLE:
byte[] readBuffer = new byte[20];
try
{
while (inputStream.available() > 0)
{
int numBytes = inputStream.read(readBuffer);
}
System.out.print(new String(readBuffer));
}
catch (IOException e)
{
e.printStackTrace();
}
break;
}
}
}
答案 0 :(得分:1)
在您的代码中(为了示例的目的,删除了异常处理):
byte[] readBuffer = new byte[20];
while (inputStream.available() > 0)
{
int numBytes = inputStream.read(readBuffer);
}
System.out.print(new String(readBuffer));
你有一个20字节的缓冲区,无论你读了多少数据,你都要从所有20个字节构造一个String
。在Java中,String
可以包含空值,因此您的字符串最终成为一个字符,后跟19个空值。然后,当您打印它时,您的特定控制台将显示空格而不是空值。
需要注意的事项。首先,你对这个循环的尝试并不是很清楚。无论在流上剩下多少字节,您都会反复读入相同的20字节缓冲区(例如,如果有400个字节要读取,最多readBuffer
最后会有最后20个字节。)
其次,为了解决我刚才描述的字符串问题,你只想使用实际从readBuffer
读取的字节,即缓冲区的第一个numBytes
字节。
第三,在从原始字节构造String
时,应始终指定字符编码。对于您的数据,似乎us-ascii
是合适的。
这样的事情,例如:
byte[] readBuffer = new byte[20];
while (inputStream.available() > 0) {
int numBytes = inputStream.read(readBuffer);
System.out.print(new String(readBuffer, 0, numBytes, "us-ascii"));
}