由于项目的需要,使用Java开发Windows桌面应用,调用外设的C语言写的驱动,看了下jni,过程太复杂,果断放弃。于是在github上找到了下面的项目:
https://github.com/java-native-access/jna
JNA的全称是Java Native Access,你只要在一个java接口中描述本地库中的函数与结构, JNA将在运行期动态访问本地库,自动实现Java接口到本地库函数的映射。
使用maven可以直接加入下面的依赖:
<dependency> <groupId>net.java.dev.jna</groupId> <artifactId>jna</artifactId> <version>4.5.1</version> </dependency> <dependency> <groupId>net.java.dev.jna</groupId> <artifactId>jna-platform</artifactId> <version>4.5.1</version> </dependency>
项目中有一个QDPos.dll,提供了两个函数用于设备的枚举,其文件头的声明如下:
BOOL WINAPI enumBloothPos(WCHAR* filter,WCHAR* deviceNames[10]);
BOOL WINAPI enumCOMPos(WCHAR* filter,TCHAR* comNames[10]);
对应的jna接口为:
QDPos INSTANCE = (QDPos) Native.loadLibrary("QDPos", QDPos.class);
package qdone.pos; import com.sun.jna.Native; import com.sun.jna.WString; import com.sun.jna.platform.win32.WinDef; import com.sun.jna.win32.StdCallLibrary; public interface QDPos extends StdCallLibrary { /**枚举蓝牙设备*/ WinDef.BOOL enumBloothPos(WString filter, WString[] deviceNames); /**枚举串口设备*/ WinDef.BOOL enumCOMPos(WString filter, WString[] deviceNames);
}
将QDPos.dll放到类搜索路径下或者Windows系统目录下,保证java在运行时能找到QDPos.dll,直接调用该接口就可以访问dll中对应的C语言实现的函数,以下为java中调用的测试用例:
@Test public void enumBloothPos() { QDPos qdPos=QDPos.INSTANCE; WString[] deviceNames=new WString[10]; WString perfix=new WString("M36"); qdPos.enumBloothPos(perfix,deviceNames); for(WString deviceName:deviceNames) { if(null!=deviceName) { logger.info("蓝牙设备:{}", deviceName); } } } @Test public void enumCOMPos() { QDPos qdPos=QDPos.INSTANCE; WString[] deviceNames=new WString[10]; WString perfix=new WString("Landi"); qdPos.enumCOMPos(perfix,deviceNames); for(WString deviceName:deviceNames) { if(null!=deviceName) { logger.info("串口设备:{}", deviceName); } } }
关于java和C语言头文件中数据类型映射,项目中给出了说明:
Default Type Mappings
Java primitive types (and their object equivalents) map directly to the native C type of the same size.
Native Type | Size | Java Type | Common Windows Types |
char | 8-bit integer | byte | BYTE, TCHAR |
© 版权声明
文章版权归作者所有,未经允许请勿转载。
THE END