JNI DETECTED ERROR IN APPLICATION: attempt to set field byte com.shares.sdk.callinfo.BatteryStatus.battery_remaining with value of wrong type: L
08-04 17:11:07.529 2447-2505/com.shares.sdk.pvsdkapitest A/art: art/runtime/check_jni.cc:70] in call to SetObjectField
08-04 17:11:07.529 2447-2505/com.shares.sdk.pvsdkapitest A/art: art/runtime/check_jni.cc:70] "Thread-1130" prio=5 tid=24 Runnable
08-04 17:11:07.529 2447-2505/com.shares.sdk.pvsdkapitest A/art: art/runtime/check_jni.cc:70] | group="main" sCount=0 dsCount=0 obj=0x12ea10a0 self=0xeec75400
08-04 17:11:07.529 2447-2505/com.shares.sdk.pvsdkapitest A/art: art/runtime/check_jni.cc:70] | sysTid=2505 nice=0 cgrp=default sched=0/0 handle=0xef047000
08-04 17:11:07.529 2447-2505/com.shares.sdk.pvsdkapitest A/art: art/runtime/check_jni.cc:70] | state=R schedstat=( 10710532 5781384 279 ) utm=1 stm=0 core=3 HZ=100
08-04 17:11:07.529 2447-2505/com.shares.sdk.pvsdkapitest A/art: art/runtime/check_jni.cc:70] | stack=0xe048b000-0xe048d000 stackSize=1012KB
08-04 17:11:07.529 2447-2505/com.shares.sdk.pvsdkapitest A/art: art/runtime/check_jni.cc:70] | held mutexes= "mutator lock"(shared held)
08-04 17:11:07.529 2447-2505/com.shares.sdk.pvsdkapitest A/art: art/runtime/check_jni.cc:70] (no managed stack frames)
问题原因:
_voltagesArray是数组,
SetObjectField应该给数组那个field赋值,付错了
jclass gpicls=sdkenv->GetObjectClass(batteryStatusobj);
jfieldID
jvoltages = sdkenv->GetFieldID(gpicls, "voltages", "[S");
jfieldID jbattery_remaining = sdkenv->GetFieldID(gpicls, "battery_remaining", "B");
jfieldID jtemperature = sdkenv->GetFieldID(gpicls, "temperature", "S");
jshortArray _voltagesArray=sdkenv->NewShortArray(sizeof(info.voltages));
//memcpy(_voltagesArray,info.voltages,sizeof(info.voltages));
sdkenv->SetShortArrayRegion(_voltagesArray,0,9,(jshort *)info.voltages);
sdkenv->SetObjectField(
batteryStatusobj,jvoltages,_voltagesArray);——
这里错了,应该是jvoltages
sdkenv->SetByteField(batteryStatusobj, jbattery_remaining,info.battery_remaining);
sdkenv->SetShortField(batteryStatusobj, jtemperature,info.temperature);
sdkenv->CallVoidMethod(globalcallBack, jmid, info,batteryStatusobj);