Это не проблема Java и JNI, а проблема вызова функции var args в C с динамическим списком аргументов.
См. Динамический вызов функции C с аргументом varargs , который предполагает наличие двух версий функции var args (хотя я думаю, что соглашение больше разрешает проход через существующий va_list
, чем для его создания который, кажется, весьма вовлечен)).
Бит JNI должен просто определять нативный метод Java с аргументами массива объектов, которые будут иметь эквивалент C, получающий массив. Используйте API JNI для преобразования значений в эквиваленты C (целые числа и строки ANSI), затем загрузите их в структуру var args и вызовите функцию vadd_row()
.
Java:
package mypackage;
public class MyClass {
...
public native void addRow(Object[] args);
...
}
C
void vadd_row(int arg1, int arg2, va_list argp) {
... your function ...
}
void add_row(int arg1, int arg2, ...) {
va_list argp;
va_start(argp, arg2);
vadd_row(int arg1, int arg2, argp);
va_end(argp);
}
JNIEXPORT void JNICALL mypackage_MyClass_addRow(JNIEnv *env, jobject this, jint arg1, jint arg2, jobjectArray jarg_array) {
va_list argp;
/* need to construct argp, see link below for hints[1]; go through each element
of the java array, get the object; convert to primitive value or ANSI string,
then encode it into the va_list */
vadd_row((int)arg1, (int)arg2, argp);
}
[1] https://bbs.archlinux.org/viewtopic.php?pid=238721
Стоит ли хлопот?
Попробуйте написать простую функцию C, которая получает аргументы в массиве, а затем создайте оболочку, которая при необходимости использует var args.