JNA指针检索值

use*_*254 3 c java native jna

我正在使用JNA访问一个DLL,一切正常......我正在调试!

问题是我在非调试模式下运行我的java代码.

通过在字符串中传递somme参数并使用结果填充char指针来调用dll的目的.

所以要在java中检索结果我正在使用PointerByReference对象.当我在调试时没有问题,我得到了正确的结果,但我的结果中只有一个特征在于标准的运行过程.

这是我的java调用:

PointerByReference EXMES = new PointerByReference();
PointerByReference SCHAINE = new PointerByReference();
DoubleByReference dateDujour = new DoubleByReference(DATEJOUR);

log.debug(String.format("Appel avec les arguments : ECHAINE=[%s]; DATEJOUR=[%s]", echaine, sdf.format(dateEngagement)));

Map<String, Object> options = new HashMap<String, Object>();
options.put(Library.OPTION_TYPE_MAPPER, W32APITypeMapper.ASCII);

log.error(String.format("Default Charset : [%s]", Charset.defaultCharset().displayName()));
Native.setProtected(true);
MyNativeLibrary library = (MyNativeLibrary) Native.loadLibrary("myLib", MyNativeLibrary.class, options);
library = (MyNativeLibrary) Native.synchronizedLibrary(library);

String chaineAscii = new String("DATE_NAISSANCE\n19780102\nMEDIA\n4\n".getBytes(Charset.forName("US-ASCII")));

log.error(String.format("ECHAINE [%s]", chaineAscii));

library.SATINTS(chaineAscii, SCHAINE, dateDujour, EXMES);

String chaineSortie = new String(SCHAINE.getPointer().getString(0, false).getBytes(Charset.forName("US-ASCII")));
String chaineExmes = new String(EXMES.getPointer().getString(0, false).getBytes(Charset.forName("US-ASCII")));

log.debug(String.format("Retour taille Prexis : SCHAINE=[%d]; EXMES=[%d]", chaineSortie.length(), chaineExmes.length()));
log.debug(String.format("Retour Prexis : SCHAINE=[%s]; EXMES=[%s]", chaineSortie, chaineExmes));
Run Code Online (Sandbox Code Playgroud)

这是我的C函数的摘录:

#define PRX_ALPHA char
#define EALPHA PRX_ALPHA *
#define SALPHA PRX_ALPHA *

EALPHA CHAINE;
SALPHA SCHAINE;
EDATE DATEJOUR;
SALPHA EXMES;

int winapi myFunction(
CHAINE,
SCHAINE,
DATEJOUR,
EXMES
) {


// Do something with the CHAINE and DATEJOUR then fill SCHAINE and EXMES with an answer
to my call
Run Code Online (Sandbox Code Playgroud)

提前为每一个帮助提醒,我被困住了

tec*_*age 7

PointerByReference相当于C中的void**.这与您的原生函数原型匹配.

String相当于const char*.您的本机代码对该参数指向的内存所做的任何更改都将被忽略.如果要为填充缓冲区提供本机代码,请使用byte[]Memory.

Memory.getString(0)或者Native.toString(byte[])可以用于String从结果中构造Java ,而不是相当冗长的String构造函数.