Android_NDK JNI实现Android Parcel(D9)

Android_NDK JNI实现Android Parcel

Parcel 原理

  1. 通过C结构体存储对象,返回结构体首地址(long类型)
  2. java层获取long之后申请从native层按照顺序写入数据
  3. 把long值传递给另外的地方
  4. 通过long值拿到native层的对象
  5. 通过顺序读取顺序

Parcel 思路实现

// 结构体和对象 Parcel.cpp
class Parcel{
    char* mData;// char 1 共享内存的首地址
    int mDataPos = 0; // =0 结构体指针偏移量,必须设置默认值

public:
    Parcel(){
        mData = (char *) malloc(1024);
    }

    void writeInt(jint value) {
        *reinterpret_cast(mData+mDataPos) = value;// 0 4
        mDataPos += sizeof(int);
    }

    void setDataPosition(jint position) {
        mDataPos = position;
    }

    jint readInt() {
        int result = *reinterpret_cast(mData+mDataPos);// 0 -> 12
        mDataPos += sizeof(int);
        return result;
    }
};

JNIEXPORT jlong JNICALL Java_com_sweet_lib_1network_Parcel_nativeCreate
        (JNIEnv *, jobject){
    Parcel *parcel = new Parcel();
    return (jlong)parcel;
}

JNIEXPORT void JNICALL Java_com_sweet_lib_1network_Parcel_nativeWriteInt
        (JNIEnv *, jobject,jlong nativePtr,jint value){
    // 写
    Parcel* parcel = reinterpret_cast(nativePtr);
    parcel->writeInt(value);
}

JNIEXPORT void JNICALL Java_com_sweet_lib_1network_Parcel_nativeSetDataPosition
        (JNIEnv *, jobject,jlong nativePtr,jint value){
    Parcel *parcel = (Parcel *) nativePtr;
    parcel->setDataPosition(value);
}

JNIEXPORT jint JNICALL Java_com_sweet_lib_1network_Parcel_nativeReadInt
        (JNIEnv *, jobject,jlong nativePtr){
    Parcel *parcel = (Parcel *) nativePtr;
    return parcel->readInt();
}

共享内存

  • binder使用共享内存,只用完成一次内存拷贝,性能更高
  • parcelable和serializable相比前者是共享内存,后者则是io序列化

你可能感兴趣的:(Android,Dev,ABC,Android_NDK,Android,android,ndk,c++,aapt)