ByReference类有很多子类,这些类都非常有用。

ByteByReferenceDoubleByReferenceFloatByReferenceIntByReferenceLongByReferenceNativeLongByReferencePointerByReferenceShortByReferenceW32API.HANDLEByReferenceX11.AtomByReferenceX11.WindowByReference

ByteByReference等类故名思议,就是指向原生代码中的字节数据的指针。

PointerByReference类表示指向指针的指针。

在JNA中模拟指针,最常用到的就是Pointer类和PointerByReference类。Pointer类代表指向任何东西的指针,PointerByReference类表示指向指针的指针。Pointer类更加通用,事实上PointerByReference类内部也持有Pointer类的实例。

Native Type Java Type
void ** PointerByReference
void* Pointer
char** PointerByReference
char& PointerByReference
char* Pointer
int& IntByReference
int* IntByReference

C++接口

//////////////////////////////////////////////////////////////////////////
//TCP参数初始化
//功能:通过参数传入,初始化TCP,为打开连接做准备
//参数:
// pHandle 为保存打开的端口句柄
// pHostName 本机的IP地址,仅在网络通讯模式下有效
// nsocketPort 网络SOCKET端口
//返回值: true为操作成功, false为操作失败
//////////////////////////////////////////////////////////////////////////
bool RFID_API STDCALL SAAT_TCPInit(void** pHandle,char *pHostName,int nsocketPort); //////////////////////////////////////////////////////////////////////////
//打开读写器
//功能: 创建网络连接
//参数:
// pHandle 为保存打开的端口句柄
//返回值: true为操作成功, false为操作失败
//////////////////////////////////////////////////////////////////////////
bool RFID_API STDCALL SAAT_Open(void* pHandle); //////////////////////////////////////////////////////////////////////////
//系统信息查询
//功能:查询读写器参数
//参数:
// pHandle: 打开的端口句柄
// nType : 要查询的参数类型
// nType 定义 长度
// 0x00 读写器名称 8字节
// 0x01 读写器产品型号 5字节
// 0x02 读写器出厂产品序列号 8字节
// 0x03 读写器处理器软件版本号 4字节
// 0x04 读写器解码单元软件版本号 4字节
// 0x05 基带电路硬件版本号 4字节
// 0x06 射频电路硬件版本号 4字节
// pPara: 指向接收读写器参数数据内存的指针
// pLen: pLen指向的内存长度
//返回值: true为操作成功, false为操作失败
bool RFID_API STDCALL SAAT_SysInfQuery (void* pHandle ,unsigned char nType, unsigned char *pPara, unsigned char *pLen); //////////////////////////////////////////////////////////////////////////
//有源-发送标签主动上传命令
//功能: 有源-发送标签主动上传命令
//参数:
// pHandle 为已经初始化的端口句柄
// nOpType: 为操作模式,
// 操作模式:
// 00:对同一个标签的ID码读写器只向上位机返回一次,
// 并要求上位机接收后给予读写器"返回数据确认",
// 01":读写器将读取到的所有的标签ID码全部上传到上位机并不要求上位机接收后给予
// 读写器"返回数据确认",直到上位机下发"关功放"命令后才停止读标签ID码。
// nIDType 要接收的ID编码
//返回值: true为操作成功, false为操作失败
//////////////////////////////////////////////////////////////////////////
bool RFID_API STDCALL SAAT_YMakeTagUpLoadIDCode ( void *pHandle,
unsigned char nOpType,
unsigned char nIDType); //////////////////////////////////////////////////////////////////////////
//接收有源ID码命令
//功能:用于接收ID码, ID码为十进制
//参数:
// pHandle 为已经初始化的端口句柄
// nTagType 为标签标记,0x00表示普通标签;0x01表示温度标签;0x02表示激励标签
// pId 为十进制int型ID,
// nBit 为标签标记
// 域 保留 标签ID类型 省电标记 传感标记 按键标记 报警标记 低压标记
// 位 2 1 1 1 1 1 1
// nParam1 温度标签整数 or 激励地址
// nParam2 温度标签小数 or 场强强度
//返回值: 1为操作成功, 0为操作失败
//////////////////////////////////////////////////////////////////////////
int RFID_API STDCALL SAAT_YRevIDMsgDecExpand(void *pHandle,unsigned char* nTagType,unsigned int* pId,unsigned char* pBit, int* nParam1, int* nParam2);

java对应接口与实现

package com.other;

import com.sun.jna.Memory;
import com.sun.jna.Native;
import com.sun.jna.Pointer;
import com.sun.jna.ptr.IntByReference;
import com.sun.jna.ptr.PointerByReference;
import com.sun.jna.win32.StdCallLibrary; public class HTRFID { public interface JnaCallBackDll extends StdCallLibrary { public static JnaCallBackDll instance = (JnaCallBackDll) Native.loadLibrary("src/main/resources/RFIDAPI.dll",
JnaCallBackDll.class); boolean SAAT_TCPInit(PointerByReference pointer, String pHostName, int nsocketPort); boolean SAAT_Open(Pointer pointer); boolean SAAT_YMakeTagUpLoadIDCode(Pointer pointer, byte nOpType, byte nIDType); int SAAT_YRevIDMsgDecExpand(Pointer pointer, Pointer nTagType, IntByReference pId, Pointer pBit,
IntByReference nParam1, IntByReference nParam2); boolean SAAT_SysInfQuery(Pointer pointer, byte nType, Pointer pPara, Pointer pLen); } public static void main(String[] args) throws Exception { PointerByReference pointer = new PointerByReference(Pointer.NULL);
boolean t = JnaCallBackDll.instance.SAAT_TCPInit(pointer, "192.168.3.219", 7086);
System.out.println("初始化:" + t);
t = JnaCallBackDll.instance.SAAT_Open(pointer.getValue());
System.out.println("打开连接:" + t);
Thread.sleep(2000); Pointer pPara = new Memory(1024);
Pointer pLen = new Memory(1024);
t = JnaCallBackDll.instance.SAAT_SysInfQuery(pointer.getValue(), new Byte("00"), pPara, pLen);
byte[] bytes = pPara.getByteArray(0, 8);
String sysinfo = new String(bytes);
System.out.println("读写器名称:" + sysinfo.substring(0,5)); t = JnaCallBackDll.instance.SAAT_YMakeTagUpLoadIDCode(pointer.getValue(), new Byte("01"), new Byte("01"));
System.out.println("主动查询:" + t); while (true) {
Pointer nTagType = new Memory(1024);
IntByReference pId = new IntByReference();
pId.setValue(0);
Pointer pBit = new Memory(1024);
IntByReference nParam1 = new IntByReference();
nParam1.setValue(0);
IntByReference nParam2 = new IntByReference();
nParam2.setValue(0);
int result = JnaCallBackDll.instance.SAAT_YRevIDMsgDecExpand(pointer.getValue(), nTagType, pId, pBit,
nParam1, nParam2); if (result == 1) {
System.out.println("标签编号" + pId.getValue());
System.out.println("激励地址" + nParam1.getValue());
System.out.println("场强强度" + nParam2.getValue());
}
}
} }

Java JNA (四)—— void**、void*、char**、char*、int*等类型映射关系及简单示例的更多相关文章

  1. Mysql,Oracle与Java字段类型映射关系

    Mysql,Oracle与Java字段类型映射关系 参考相关博文 MySQL/Oracle字段类型 Java字段类型 最大长度 BIT java.lang.Boolean 1 BLOB java.la ...

  2. Java swing(awt):事件监听机制的实现原理+简单示例

    (1)实现原理 事件监听机制的实现: 参考图:事件模型_ActionEvent 为了节省资源,系统无法对某个事件进行实时的监听.故实现的机制是当发生某个事件后,处理代码将被自动运行,类似钩子一般.(回 ...

  3. Java 调用 C/C++ 之 JNA 系列实战篇 —— 输出char * (六)

    一. 工作环境 1. windows (64位), JDK (64位),dll文件 (64位) 2. Linux (64位),      JDK (64位),so文件 (64位) 3. JNA的官方资 ...

  4. java.lang基础数据类型boolean、char、byte、short、int、long、float、double (JDK1.8)

    java.lang.Boolean public static int hashCode(boolean value) { return value ? 1231 : 1237; } JDK 1.8新 ...

  5. java学习日志--char和int的相互转换

    package shugen; /*ASCLL码表 * 48 数字0 * 49 1 * 50 2 * 51 3 * 52 4 * 53 5 * 54 6 * 55 7 * 56 8 * 57 9 */ ...

  6. 一段代码了解Java中char和int的转换

    题目要求: 将输入的大写字母转成对应小写的后5个,如A转换后为f:如果转换后大于z则从a重新计,即多出1就转成a,多出2就转成b以此类推. Java代码: ```java private static ...

  7. Java中基本数据类型byte,short,char,int,long,float,double 取值范围

    部分内容转自:java 彻底理解 byte char short int float long double 首先说byte: 这段是摘自jdk中 Byte.java中的源代码: /** * A co ...

  8. void die(const char *msg)

    void die(const char *msg) { perror(msg); exit(errno); }

  9. [转] java中int,char,string三种类型的相互转换

    原文地址:http://blog.csdn.net/lisa0220/article/details/6649707 如何将字串 String 转换成整数 int? int i = Integer.v ...

随机推荐

  1. sh_01_hello

    sh_01_hello print("hello python") print("你好世界")

  2. WEB Fuzz中需要关注的7种响应

    WEB应用模糊测试(WEB Fuzz)是一种特殊形式的网络协议模糊测试,专门关注遵循HTTP规范的网络数据包. WEB Fuzz并不是新的概念,目前有多种WEB应用模糊测试器(WEB Fuzzer), ...

  3. 一台电脑多个git使用 push 时候出现denied

    http://my.oschina.net/silentboy/blog/220158 当一台电脑上多个git account 的时候, 出现如下问题, $ git push origin maste ...

  4. java将url里面的中文改成ASCII字符集 和 SCII字符集 改成 中文

    package com.example.demo; import java.io.UnsupportedEncodingException; import java.net.URLDecoder; / ...

  5. python安装使用(windows)

    安装 参考:http://scrapy-chs.readthedocs.io/zh_CN/0.24/intro/install.html#scrapy 用到的文件:https://share.weiy ...

  6. 小程序框架MpVue踩坑日记(二)

    数据嵌套超过三层或者等于三层的时候 父组件传值给子组件后,如果子组件内的值需要改变 通过this.emit()传值后,父组件的值虽然会改变,但是视图并不会重新渲染 原因就是数据嵌套太多,没有触发ren ...

  7. (三)Maven之仓库

    目录 引言:坐标和依赖是一个构件在Maven世界中逻辑表示方式,而构件的物理表示方式就是文件而已,仓库就是统一管理这些文件的地方. 目录 仓库类别 本地仓库 远程仓库: 中仓仓库(自带的默认远程仓库) ...

  8. VS2013中使用本地IIS+域名调试ASP.NET项目

    VS2013中使用本地IIS+域名调试ASP.NET项目 在有些情况下需要使用本地的IIS作为调试服务器,如支持多域名的网站,这里记录下如何使用. 1.修改本机hosts文件. 路径:C:\Windo ...

  9. Mac 10.14 下为php 安装xdebug 并让vscode支持

    安装Xdebug 寻找对应php版本的xdebug版本 先将info输出到一个文件 php -i > info.txt 打开info.txt 复制所有内容 打开寻找合适xdebug的页面http ...

  10. exsi中使用vSphere客户端复制克隆虚拟机

    免费的VMWare ESXi5.5非常强大,使用ESXi经常会遇到这样的问题,我需要建立多个虚拟机,系统一个一个安装很麻烦.VMware ESXi.VMware vCenter Server 和 vS ...