我正在使用JNA访问dll,一切正常......当我在调试时!!!
问题是我在非调试模式下运行我的java代码。
通过在字符串中传递somme参数来调用dll的目的 用结果填充char指针。
所以要在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));
这是我的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
提前为每一个帮助提醒,我被困住了
答案 0 :(得分:7)
PointerByReference
相当于C中的void **。不匹配您的原生函数原型。
String
相当于const char*
。您的本机代码对该参数指向的内存所做的任何更改都将被忽略。如果要为填充缓冲区提供本机代码,请使用byte[]
或Memory
。
Memory.getString(0)
或Native.toString(byte[])
从结果中构建Java String
,而不是使用相当冗长的String
构造函数。