自定义结构体在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里解析就可以。