Найден способ возврата сложных моделей (Object с подчиненными объектами и ArrayList с Object-элементами) из C в Java. Но у меня есть еще одна проблема: утечки памяти.
В настоящее время код, над которым я работаю, анализирует данные (на C) и должен возвращать данные, проанализированные в класс Java.
Основной класс Java содержит больше классов Java (ints, String, boolean, Obj, ArrayList of Objects), и я возвращаю проанализированные данные, используя этот шаблон для экземпляров Object:
// Instance:LyricsLineVo
jclass findClsLyricsLine = (*env)->FindClass(env, "com/example/jni/vo/LyricsLineVo");
jmethodID initLyricsLine = (*env)->GetMethodID (env, findClsLyricsLine, initMethod,"()V");
jobject objLyricsLine = (*env)->NewObject(env, findClsLyricsLine, initLyricsLine);
jclass classLyricsLine = (*env)->GetObjectClass(env, objLyricsLine);
Код слишком длинный, и я не знаю, следует ли мне отделять другие объекты от другой функции и просто передавать проанализированные данные каждой из разных функций, я думаю, что это будет занимать больше памяти, и у меня уже есть проблемы с освобождением используемых из них.
Я прочитал несколько способов освобождения места:
Утечка памяти при использовании JNI для получения значения String из кода Java
Утечка памяти при вызове Java-кода из C с использованием JNI
Но применять их недостаточно. Он может разрешить только один анализ данных, но после этого происходит сбой моей программы.
Существуют ли другие рекомендуемые коды, которые могут уменьшить использование памяти для этого?
Я добавляю свой журнал ошибок ниже:
07-11 19:23:31.640: WARN/dalvikvm(301): ReferenceTable overflow (max=512)
07-11 19:23:31.650: WARN/dalvikvm(301): Last 10 entries in JNI local reference table:
07-11 19:23:31.650: WARN/dalvikvm(301): 502: 0x44df0930 cls=Ljava/lang/Class; 'Lcom/demo/project/vo/DurationVo;' (172 bytes)
07-11 19:23:31.650: WARN/dalvikvm(301): 503: 0x44df51a8 cls=Lcom/demo/project/vo/DurationVo; (20 bytes)
07-11 19:23:31.660: WARN/dalvikvm(301): 504: 0x44df0930 cls=Ljava/lang/Class; 'Lcom/demo/project/vo/DurationVo;' (172 bytes)
07-11 19:23:31.660: WARN/dalvikvm(301): 505: 0x4002afc8 cls=Ljava/lang/Class; 'Ljava/util/ArrayList;' (172 bytes)
07-11 19:23:31.660: WARN/dalvikvm(301): 506: 0x44df5280 cls=Ljava/util/ArrayList; (28 bytes)
07-11 19:23:31.660: WARN/dalvikvm(301): 507: 0x44df0338 cls=Ljava/lang/Class; 'Lcom/demo/project/vo/MeasureTrackPairVo;' (172 bytes)
07-11 19:23:31.660: WARN/dalvikvm(301): 508: 0x44df52a0 cls=Lcom/demo/project/vo/MeasureTrackPairVo; (28 bytes)
07-11 19:23:31.660: WARN/dalvikvm(301): 509: 0x44df0338 cls=Ljava/lang/Class; 'Lcom/demo/project/vo/MeasureTrackPairVo;' (172 bytes)
07-11 19:23:31.660: WARN/dalvikvm(301): 510: 0x4002afc8 cls=Ljava/lang/Class; 'Ljava/util/ArrayList;' (172 bytes)
07-11 19:23:31.660: WARN/dalvikvm(301): 511: 0x44df5320 cls=Ljava/util/ArrayList; (28 bytes)
07-11 19:23:31.680: WARN/dalvikvm(301): JNI local reference table summary (512 entries):
07-11 19:23:31.690: WARN/dalvikvm(301): 322 of Ljava/lang/Class; 172B (11 unique)
07-11 19:23:31.690: WARN/dalvikvm(301): 7 of Ljava/lang/Integer; 12B (7 unique)
07-11 19:23:31.690: WARN/dalvikvm(301): 10 of Ljava/lang/String; 28B (10 unique)
07-11 19:23:31.690: WARN/dalvikvm(301): 33 of Ljava/util/ArrayList; 28B (33 unique)
07-11 19:23:31.690: WARN/dalvikvm(301): 1 of Lcom/demo/project/vo/HeaderVo; 60B
07-11 19:23:31.700: WARN/dalvikvm(301): 1 of Lcom/demo/project/vo/LyricsVo; 20B
07-11 19:23:31.700: WARN/dalvikvm(301): 1 of Lcom/demo/project/vo/LyricsLineVo; 20B
07-11 19:23:31.700: WARN/dalvikvm(301): 18 of Lcom/demo/project/vo/MeasureHeaderVo; 36B (18 unique)
07-11 19:23:31.710: WARN/dalvikvm(301): 1 of Lcom/demo/project/vo/TrackHeaderVo; 60B
07-11 19:23:31.710: WARN/dalvikvm(301): 14 of Lcom/demo/project/vo/MeasureTrackPairVo; 28B (14 unique)
07-11 19:23:31.710: WARN/dalvikvm(301): 52 of Lcom/demo/project/vo/BeatVo; 60B (52 unique)
07-11 19:23:31.710: WARN/dalvikvm(301): 52 of Lcom/demo/project/vo/DurationVo; 20B (52 unique)
07-11 19:23:31.710: WARN/dalvikvm(301): Memory held directly by native code is 8540 bytes
07-11 19:23:31.720: ERROR/dalvikvm(301): Failed adding to JNI local ref table (has 512 entries)