在JNI

2017-07-17 71 views
0

附加的字節數組轉換的Java追加功能JNI當我在遇到麻煩。如果有人可以幫助這個,我會很感激。在Java中在JNI

/* 
private byte[] append(byte[]... dtIn) { 

    // get dtIn length 
    int length = 0; 
    for (byte[] d : dtIn) { 
     length += d.length; 
    } 

    // allocate memory 
    ByteBuffer b = ByteBuffer.allocate(length); 

    // append dtIn 
    for (int i = 0; i < dtIn.length; i++) { 
     b.put(dtIn[i]); 
    } 
    return b.array(); 
} 
*/ 


private native byte[] append(byte[]... dtIn); 

static { 
    System.loadLibrary("mylibs"); 
} 

JNI

全局常量

const char *CLS_BYTE_BUFFER = "java/nio/ByteBuffer"; 
const char *MID_ALLOCATE = "allocate"; 
const char *SIG_ALLOCATE = "(I)Ljava/nio/ByteBuffer;"; 
const char *MID_PUT= "put"; 
const char *SIG_PUT = "(B)Ljava/nio/ByteBuffer;"; 
const char *MID_ARRAY = "array"; 
const char *SIG_ARRAY = "()[B"; 

全局變量

的Java

附加功能

JavaVM *_jvm; 
jclass _clsByteBuffer; 
jmethodID _midAllocate, _midPut, _midArray; 

當執行System.loadLibrary(「mylibs」)時,將調用此函數。

JNIEXPORT jint JNICALL 
JNI_OnLoad(JavaVM *jvm, void *reserved) { 
    jclass clsByteBuffer; 

    JNIEnv *env; 

    _jvm = jvm; 
    if (jvm->GetEnv((void **) &env, JNI_VERSION_1_6)) { 
     return JNI_ERR; 
    } 

    // ByteBuffer 
    clsByteBuffer = env->FindClass(CLS_BYTE_BUFFER); 
    if (clsByteBuffer == NULL || tryCatch()) { 
     return JNI_ERR; 
    } 

    _clsByteBuffer = (jclass) env->NewWeakGlobalRef(clsByteBuffer); 
    if (_clsByteBuffer == NULL || tryCatch()) { 
     return JNI_ERR; 
    } 

    // allocate 
    _midAllocate = env->GetStaticMethodID(_clsByteBuffer, MID_ALLOCATE, SIG_ALLOCATE); 
    if (_midAllocate == NULL || tryCatch()) { 
     return JNI_ERR; 
    } 

    // put 
    _midPut = env->GetMethodID(_clsByteBuffer, MID_PUT, SIG_PUT); 
    if (_midPut == NULL || tryCatch()) { 
     return JNI_ERR; 
    } 

    // array 
    _midArray = env->GetMethodID(_clsByteBuffer, MID_ARRAY, SIG_ARRAY); 
    if (_midArray == NULL || tryCatch()) { 
     return JNI_ERR; 
    } 

    return JNI_VERSION_1_6; 
} 

附加功能(問題,在這裏!)

JNIEXPORT jbyteArray JNICALL 
Java_com_company_myapp_activity_test_append(JNIEnv *env, jobject instance, jobjectArray dtIn) { 

    // This works 
    JNIEnv *e = getEnv(); 
    if (e == NULL || instance == NULL || dtIn == NULL) { 
     return NULL; 
    } 

    // This works 
    jint length = 0; 
    for (jint i = 0; i < e->GetArrayLength(dtIn); i++) { 
     jbyteArray item = (jbyteArray) e->GetObjectArrayElement(dtIn, i); 
     length = length + e->GetArrayLength(item); 
    } 

    // Allocate buffers 
    jobject buffer = e->CallStaticObjectMethod(_clsByteBuffer, _midAllocate, length); 
    if (buffer == NULL || tryCatch()) { 
     return NULL; 
    } 

    // This does not worked ??? 
    for (jint i = 0; i < e->GetArrayLength(dtIn); i++) { 
     jbyteArray item = (jbyteArray) e->GetObjectArrayElement(dtIn, i); 

     e->CallVoidMethod(buffer, _midPut, item); 
    } 
    return (jbyteArray) e->CallObjectMethod(buffer, _midArray); 
} 
+0

'的javap -s的Java/NIO /字節緩衝區| grep -A 2「put(byte」'來得到put的各種簽名和字節,如果你爲一個特定的方法命名SIG_PUT,你就不會出錯 –

+0

謝謝指出 – Ihdina

回答

0

我的問題是解決了,發生是由於恆定的打字錯誤簽名,少[馬克錯誤。

更換

const char *SIG_PUT = "(B)Ljava/nio/ByteBuffer;"; 

const char *SIG_PUT = "([B)Ljava/nio/ByteBuffer;";