마스터Q&A 안드로이드는 안드로이드 개발자들의 질문과 답변을 위한 지식 커뮤니티 사이트입니다. 안드로이드펍에서 운영하고 있습니다. [사용법, 운영진]

ndk null 에러 관련 질문 드립니다.. 부탁 드립니다..

0 추천
//ndk null 에러난거 같은데 코드 첨부 합니다. 어디 부분이 잘못된지 알려주세요.ㅠㅠ


JNIEXPORT jint JNI_OnLoad(JavaVM *vm, void *reserved) {
    g_vm = vm;
    return JNI_VERSION_1_6;
}
//==============================================================================

typedef struct _TJNI_HANDLE {
    jobject obj;
} TJNI_HANDLE, *PTJNI_HANDLE;
void callbackStream(int nFD, unsigned char unPLPId, unsigned char *pALPData, int nLength, void *pUserData) {

    // Add
    if(pUserData == nullptr) {
        return;
    }

    PTJNI_HANDLE handle = (PTJNI_HANDLE) pUserData;
    jobject obj = handle->obj;

    // Add
    if(obj == nullptr) {
        return;
    }


    JNIEnv *env;
    int nEnvStat;

    nEnvStat = g_vm->GetEnv((void **) &env, JNI_VERSION_1_6);

    if (unPLPId == GHOST_CALLBACK_START) {
        if (nEnvStat == JNI_EDETACHED) {
            g_vm->AttachCurrentThread(&env, nullptr);
        } else if (nEnvStat == JNI_OK) {
            // Success. do nothing.
        } else {
            // error.
            return;
        }

        if (nLength <= 0) {
            return;
        }

        jclass cls = env->GetObjectClass(obj);
        jmethodID mid = env->GetMethodID(cls, "callbackStream", "(IB[B)V");

        if (mid == nullptr) {
            env->DeleteLocalRef(cls);
            return;
        }

        jbyteArray jbyteArrayData = env->NewByteArray(nLength);
        if(jbyteArrayData == nullptr){
            env->DeleteLocalRef(cls);
            return;
        }
        jbyte *jbyteData = env->GetByteArrayElements(jbyteArrayData, nullptr);
        memcpy(jbyteData, pALPData, nLength);
        env->ReleaseByteArrayElements(jbyteArrayData, jbyteData, 0);

        env->CallVoidMethod(obj, mid, nFD, unPLPId, jbyteArrayData);

        env->DeleteLocalRef(jbyteArrayData);
        env->DeleteLocalRef(cls);
    }
    else if (unPLPId == GHOST_CALLBACK_STOP) {
        if (nEnvStat == JNI_OK) {
            g_vm->DetachCurrentThread();
        }
    }
}
extern "C" jint Java_com_onpoom_uhdreceiverandroid_UHDSignal_AtbisAtsc3Jni_init(JNIEnv *env, jobject obj, jint fd) {
    PTJNI_HANDLE handle = new TJNI_HANDLE;
    handle->obj = env->NewGlobalRef(obj);

    jint result = GhostInit(fd, callbackStream, handle);
    if (result < 0) {
        delete handle;
    }

    return result;
}
 //에러 코드가 길어서 핵심 부분은 
2019-11-01 00:44:39.293 3791-3791/? A/DEBUG: pid: 1492, tid: 3726, name: pool-801-thread  >>> com.onpoom.uhdreceiverandroid <<<
2019-11-01 00:44:39.293 3791-3791/? A/DEBUG: signal 6 (SIGABRT), code -6 (SI_TKILL), fault addr --------
2019-11-01 00:44:39.295 3791-3791/? A/DEBUG: Abort message: 'art/runtime/java_vm_ext.cc:470] JNI DETECTED ERROR IN APPLICATION: field operation on NULL object: 0x0'

 

자몽라면 (300 포인트) 님이 2019년 11월 4일 질문

답변 달기

· 글에 소스 코드 보기 좋게 넣는 법
· 질문에 대해 추가적인 질문이나 의견이 있으면 답변이 아니라 댓글로 달아주시기 바랍니다.
표시할 이름 (옵션):
개인정보: 당신의 이메일은 이 알림을 보내는데만 사용됩니다.
스팸 차단 검사:
스팸 검사를 다시 받지 않으려면 로그인하거나 혹은 가입 하세요.
...