0

PS: 実際、これは機能しています。この質問をすぐに更新するという別の問題があります。

次のネイティブコードがあります。

JNIEXPORT void JNICALL Java_com_rmsdk_wrapper_RMServices_init(JNIEnv *env, jobject thiso,
        jstring prodName, jstring version) {

    jclass thisClass = env->GetObjectClass(thiso);

    __android_log_print(ANDROID_LOG_DEBUG, "APP", "[findMethodId]");        
    jmethodID getDeviceName = env->GetMethodID(thisClass, "getDeviceName", "()Ljava/lang/String;");

    __android_log_print(ANDROID_LOG_DEBUG, "APP", "[invoke]");      
    jstring dvcName = (jstring) env->CallObjectMethod(thiso, getDeviceName);

    __android_log_print(ANDROID_LOG_DEBUG, "APP", "[strings retrivied]");

そして、Java クラスのそれぞれのメソッド

public String getDeviceName() {
    String deviceName = Build.MODEL;
    LogU.v("APPServices", "getDeviceName("+deviceName+")");
    return deviceName;
}

しかし、実行すると次のことが起こります。

D/RMSDK:DRM(3717): [findMethodId]
D/RMSDK:DRM(3717): [invoke]
I/DEBUG(27674): *** *** *** *** *** *** *** *** *** *** *** *** *** *** *** ***
I/DEBUG(27674): Build fingerprint: 'MOTO/PORTLA/wifi_hubble:3.2/H.6.6-27/1317781165:user/ota-rel-keys,release-keys'
I/DEBUG(27674): pid: 3717, tid: 3717  >>> br.com.abril.iba <<<
I/DEBUG(27674): signal 11 (SIGSEGV), code 1 (SEGV_MAPERR), fault addr 00000000
I/DEBUG(27674):  r0 00000000  r1 40c33038  r2 5651b1ec  r3 be86444c
I/DEBUG(27674):  r4 0000008c  r5 8282a018  r6 82805e28  r7 826f0a68

メソッドが見つかりましたが、それを呼び出すとクラッシュします (どのメソッドでも起こります)。どうすれば修正できますか? なぜ機能しないのかわかりません。

PS: Android NDK5 & NDK7B でも同じエラーが発生します

4

1 に答える 1

0

コードは私の HTC Desire Z で正常に動作します。android-ndk-r7b を使用してネイティブ部分をコンパイルしました。getDeviceName()実行するクラスと同じクラスにメソッドがありますinit(String s1, String s2);か? 次の Java コードを使用しました。

public class HelloJni extends Activity {

public native void init(String s1, String s2);



@Override
public void onCreate(Bundle savedInstanceState) {
    super.onCreate(savedInstanceState);
    setContentView(R.layout.main);
    init("","");
}

static {
    System.loadLibrary("hello-jni");
}

public String getDeviceName() {
    String deviceName = Build.MODEL;
    Log.v("APPServices", "getDeviceName("+deviceName+")");
    return deviceName;
}
}
于 2012-03-16T12:56:27.587 に答える