modbus 编程调试问题
以下是主设备代码,问题是:通过mbslave连接到pc的COM1口,然后运行程序:出现端口被未知程序占用。如果先运行程序,或出现请求无应答。mbslave也连不上COM1。希望各位能帮助解答一下。
程序是网上拷的,想先调通一下。
在网上也没有找到好的关于modbus的编程资料,在官网找到一个函数手册,但是仅仅是函数头,并没有关于函数功能的介绍如果可以的话,希望各位大大能提供一些资料。
/**
* 通过串口解析MODBUS协议
*
*
*/
public class modBus {
//设定MODBUS网络上从站地址
private final static int SLAVE_ADDRESS = 1;
// 串行波特率
private final static int BAUD_RATE = 9600;
public static void main(String[] args) {
SerialParameters serialParameters = new SerialParameters();
// 设定MODBUS通讯的串行口
serialParameters.setCommPortId("COM1");
// 设定成无奇偶校验
serialParameters.setParity(0);
// 设定成数据位是8位
serialParameters.setDataBits(8);
// 设定为1个停止位
serialParameters.setStopBits(1);
// 设定端口名称
serialParameters.setPortOwnerName("hwm");
// 设定端口波特率
serialParameters.setBaudRate(BAUD_RATE);
// 创建ModbusFactory工厂实例
ModbusFactory modbusFactory = new ModbusFactory();
// 创建ModbusMaster实例
ModbusMaster master = modbusFactory.createRtuMaster(serialParameters);
// 初始化
try {
master.init();
readHoldingRegistersTest(master,SLAVE_ADDRESS,0,100);
} catch (ModbusInitException e) {
e.printStackTrace();
} finally {
master.destroy();
}
}
/**
* 读保持寄存器上的内容
* @param master 主站
* @param slaveId 从站地址
* @param start 起始地址的偏移量
* @param len 待读寄存器的个数
*/
private static void readHoldingRegistersTest(ModbusMaster master,
int slaveId, int start, int len) {
try {
ReadHoldingRegistersRequest request = new ReadHoldingRegistersRequest(
slaveId, start, len);
ReadHoldingRegistersResponse response = (ReadHoldingRegistersResponse)
master.send(request);
if (response.isException()) {
System.out.println("Exception response: message="
+ response.getExceptionMessage());
} else {
System.out.println(Arrays.toString(response.getShortData()));
short[] list = response.getShortData();
for(int i = 0; i < list.length; i++){
System.out.print(list[i] + " ");
}
}
} catch (ModbusTransportException e) {
e.printStackTrace();
}
}
}
以下是先连接mbslave后运行程序的报错
Stable Library
=========================================
Native lib Version = RXTX-2.1-7
Java lib Version = RXTX-2.1-7
com.serotonin.modbus4j.exception.ModbusInitException: com.serotonin.io.serial.SerialPortException: gnu.io.PortInUseException: Unknown Application
at com.serotonin.modbus4j.serial.SerialMaster.init(SerialMaster.java:31)
at com.serotonin.modbus4j.serial.rtu.RtuMaster.init(RtuMaster.java:23)
at modBus.main(modBus.java:48)
Caused by: com.serotonin.io.serial.SerialPortException: gnu.io.PortInUseException: Unknown Application
at com.serotonin.io.serial.SerialUtils.openSerialPort(SerialUtils.java:55)
at com.serotonin.modbus4j.serial.SerialMaster.init(SerialMaster.java:27)
... 2 more
Caused by: gnu.io.PortInUseException: Unknown Application
at gnu.io.CommPortIdentifier.open(CommPortIdentifier.java:354)
at com.serotonin.io.serial.SerialUtils.openSerialPort(SerialUtils.java:43)
... 3 more
以下是先运行程序的报错。
Stable Library
=========================================
Native lib Version = RXTX-2.1-7
Java lib Version = RXTX-2.1-7
com.serotonin.modbus4j.exception.ModbusTransportException: com.serotonin.messaging.TimeoutException: request=com.serotonin.modbus4j.serial.rtu.RtuMessageRequest@c1b531
at com.serotonin.modbus4j.serial.rtu.RtuMaster.send(RtuMaster.java:57)
at modBus.readHoldingRegistersTest(modBus.java:74)
at modBus.main(modBus.java:49)
Caused by: com.serotonin.messaging.TimeoutException: request=com.serotonin.modbus4j.serial.rtu.RtuMessageRequest@c1b531
at com.serotonin.messaging.MessageControl.send(MessageControl.java:104)
at com.serotonin.messaging.MessageControl.send(MessageControl.java:69)
at com.serotonin.modbus4j.serial.rtu.RtuMaster.send(RtuMaster.java:51)
... 2 more
最近在做的项目需要用到,但是之前也没接触过,再次谢谢大家了。