gpt4 book ai didi

java - 读取端口数据 COMM(串行事件监听器)- Java

转载 作者:行者123 更新时间:2023-12-01 19:22:02 24 4
gpt4 key购买 nike

还好吗?我正在尝试将 C# 代码转换为 Java,但遇到了一些问题...

我正在尝试读取串行端口,

Global
private InputStream inputStream;
private OutputStream outputStream;
<小时/>
outputStream = serialPort.getOutputStream();
inputStream = serialPort.getInputStream();

发送数据,一切正常,问题是读取数据的时间。

在 C# 中,我有一个接收方法:

public void recepcaoResposta(int tam, byte[] frameHex)
{
byte[] l_frameHex = new byte[2000];
byte[] frameEvt = new byte[16];
string linha, linhaTipo;

// !! Copia vetor-parâmetro para vetor-local (evita exception nos "if's"
//caso apenas 1 byte recebido) !!
Buffer.BlockCopy(frameHex, 0, l_frameHex, 0, tam);
.....
}

转换为 Java 如下所示:

public void recepcaoResposta(int tam, byte[] frameHex) {
byte[] l_frameHex = new byte[2000];
byte[] frameEvt = new byte[16];
String linha, linhaTipo;

// !! Copia vetor-parâmetro para vetor-local (evita exception nos "if's"
//caso apenas 1 byte recebido) !!
System.arraycopy(frameHex, 0, l_frameHex, 0, tam);
...
}

到目前为止还好,问题是获取 tam 的时间,即数组的大小。在java中,我返回的大小是8,无论我做什么,都会得到8。

我什至尝试将“随机”数字大小的 if 更改为 8。但显然我遇到了错误...

@Override
public void serialEvent(SerialPortEvent event) {
switch (event.getEventType()) {
case SerialPortEvent.DATA_AVAILABLE:
try {
while (inputStream.available() > 0) {
// int t = inputStream.read();
int t = serialPort.getDataBits();
byte[] f = new byte[t];
inputStream.read(f, 0, t); // Frame de bytes
recepcaoResposta(t, f);
}

} catch (IOException e) {
System.out.println("IO Exception in SerialEvent()" + e);
}
break;
}
}

但是如上所述,我只返回了大小 8,在上面的代码中是:

int t = serialPort.getDataBits();

结果基本上是这样的:

TAM:8
l_frameHex[1]12
TAM:8
l_frameHex[1]23

最佳答案

好吧,经过多次尝试,我得到了它,它工作得很好:

public static InputStream inputStream;
public static OutputStream outputStream;

@Override
public void serialEvent(SerialPortEvent evt) {
switch (evt.getEventType()) {
case SerialPortEvent.BI:
//Quebra interupção.
case SerialPortEvent.OE:
//Erro de saturação.
case SerialPortEvent.FE:
//Erro de enquadramento.
case SerialPortEvent.PE:
//Erro de pariedade.
case SerialPortEvent.CD:
//Detecção de portadora.
case SerialPortEvent.CTS:
//Limpa para enviar.
case SerialPortEvent.DSR:
//Conjunto de dados prontos.
case SerialPortEvent.RI:
//Caminho indicado.
case SerialPortEvent.OUTPUT_BUFFER_EMPTY:
/*Buffer de saída está vazio. O evento será gerado depois de uma gravação for concluída,
quando o buffer do sistema torna-se vazia novamente..."
*/
break;
case SerialPortEvent.DATA_AVAILABLE:
/*Dados disponíveis na porta serial. "
+ "Este evento será gerada uma vez quando dados novos chegam na porta de série. "
+ "Mesmo se o usuário não ler os dados, "
+ "não será gerado novamente até a próxima vez que novos dados chegam");
*/
try {
TimeUnit.MILLISECONDS.sleep(500); //
} catch (InterruptedException e) {
}
byte[] readBuffer = new byte[1024];
try {
int numBytes = 0;
while (inputStream.available() > 0) {
numBytes = inputStream.read(readBuffer);
}
String result = new String(readBuffer);
result = result.substring(0, numBytes);
System.out.println(result + "\n");
} catch (IOException e) {
}

break;
}
}

关于java - 读取端口数据 COMM(串行事件监听器)- Java,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/59347927/

24 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com