C++通过jni向java层传递自定义结构体参数

自定义结构体在java中定义为相应的类,存储数据变量

C++的回调函数的注册函数为:

 void CCtest::registerInit(void (*pFunc)(PARAMETER*)){
    xxxxxxxx
    ...
}

现有若干问题不解。
1.该函数的函数签名的变量类型该如何进行书写?
是直接将参数看作是void类型?

 {"registerInit","()V",(void*)native_registerInit}; ?

2.假设上述问题解决。
在jni层通过定义

 static jmethodID registerInit_callback_method_ID;
typedef void (* registerInit_Cb_t)(PARAMETER* myPara);

在native_registerInit函数中直接调用

 CCtest::registerInit(registerInit_Cb_t);

registerInit_Cb_t指向具体的实现函数nativeregisterInit_Cb;

在函数void nativeregisterInit_Cb(PARAMETER*)中,通过

 env->CallVoidMethod(xxxobject,xxxmethodID,/*xxx结构体的参数如何表示成类类型?(jobject?)*/);

调用java层中的回调函数。

我印象里好像是有区分的,也是类似于传参数 时,引用对象和赋值对象的区别,要是赋值对象,比如int,float这种,是新开辟空间做的,需要定义返回值,但是如果是结构体的话,属于java的引用对象,那就是直接操作内存赋值就行了。返回值定义成void。
你看看吧:http://www.cnweblog.com/fly2700/archive/2012/03/21/320083.html

or(int i=0;i<num;i++) {

//上传任务

offset = i*UploadPartSize;

last="0";

int partSize = UploadPartSize;

if(i==num-1) {

last = "1";

partSize = (int)allSize%UploadPartSize;

}

byte[] buffer = new byte[partSize];

file.read(buffer);

File bufferStr = new File(zipfilePath + File.separator + "buffer");

if(!bufferStr.exists())

bufferStr.createNewFile();

//如果用下面的writeoutput,写入的大小总小于buffer的大小,不知道原因..切记只用fileoutput;  
//或者说读写要用一套函数,不要乱用!读用FileInputStream,写用FileOutputStream!  
//OutputStream out = new WriterOutputStream(fw);  
OutputStream out = new FileOutputStream(bufferStr);  
out.write(buffer);  
out.flush();  
out.close();  
//上传操作**********  

}

//校验总的上传的文件大小**********

你可以先传Json的string型字符串,之后在JAVA里解析就可以。