jni使用事例(jstring char*相互转换)

            

1、获得string返回值 并传递给c++:


char* huaweiUin = new char[100];

#if (CC_TARGET_PLATFORM == CC_PLATFORM_ANDROID)

jstring juid= (jstring)minfo.env->CallStaticObjectMethod(minfo.classID, minfo.methodID);    

constchar *str = minfo.env->GetStringUTFChars(juid,0); //jstring 无法直接使用 (android 实际执行的是java代码 cpp作为外部库被java调用)

strcpy(huaweiUin,str); //由于是 const char* 无法直接传递指针 使用strcpy

#endif

GetStringUTFChars(将jstring转换成为UTF-8格式的char* ->  Java基础知识——JNI入门介绍 


2、将c++中string参数 传递给java函数:

string serial;

#if (CC_TARGET_PLATFORM == CC_PLATFORM_ANDROID)

        minfo.env->CallStaticIntMethod(minfo.classID, minfo.methodID, minfo.env->NewStringUTF(serial.c_str())); 

//NewStringUTF(创建一个UTF-8格式的String对象)需要参数是utf-8格式  ->  Java基础知识——JNI入门介绍 

//->JNI学习积累之一 ---- 常用函数大全  

#endif

//只有当参数是utf-8时可以直接像上面那样用 否则需要按下面的方法

//const char类型转换成jstring类型

jstring stoJstring( JNIEnv* env, const char* pat )

{

//定义java String strClass

jclass strClass = (env)->FindClass("Ljava/lang/String;");

//获取java String类方法String(byte[],String)的构造器,用于将本地byte[]数组转换为一个新String

jmethodID ctorID = (env)->GetMethodID(strClass, "<init>", "([BLjava/lang/String;)V");

jbyteArray bytes = (env)->NewByteArray(strlen(pat));//建立byte数组

(env)->SetByteArrayRegion(bytes, 0, strlen(pat), (jbyte*)pat);//char*转换为byte数组

jstring encoding = (env)->NewStringUTF("GB2312");//设置String, 保存语言类型(utf-8,GB2312等,用于byte数组转换至String时的参数  

return (jstring)(env)->NewObject(strClass, ctorID, bytes, encoding);//byte数组转换为java String,并输出

}



以下参考:( 对于各种格式都支持 )

//jstring to char*
char* jstringTostring(JNIEnv* env, jstring jstr)
{        
char* rtn = NULL;
jclass clsstring = env->FindClass("java/lang/String");
jstring strencode = env->NewStringUTF("utf-8");
jmethodID mid = env->GetMethodID(clsstring, "getBytes", "(Ljava/lang/String;)[B");
jbyteArray barr= (jbyteArray)env->CallObjectMethod(jstr, mid, strencode);
jsize alen = env->GetArrayLength(barr);
jbyte* ba = env->GetByteArrayElements(barr, JNI_FALSE);
if (alen > 0)
{
rtn = (char*)malloc(alen + 1);
memcpy(rtn, ba, alen);
rtn[alen] = 0;
}
env->ReleaseByteArrayElements(barr, ba, 0);
return rtn;
}

//char* to jstring
jstring stoJstring(JNIEnv* env, const char* pat)
{
jclass strClass = env->FindClass("Ljava/lang/String;");
jmethodID ctorID = env->GetMethodID(strClass, "<init>", "([BLjava/lang/String;)V");
jbyteArray bytes = env->NewByteArray(strlen(pat));
env->SetByteArrayRegion(bytes, 0, strlen(pat), (jbyte*)pat);
jstring encoding = env->NewStringUTF("utf-8");
return (jstring)env->NewObject(strClass, ctorID, bytes, encoding);


//将jstring类型转换成windows类型
char* jstringToWindows( JNIEnv *env, jstring jstr )
{
int length = (env)->GetStringLength(jstr );
const jchar* jcstr = (env)->GetStringChars(jstr, 0 );
char* rtn = (char*)malloc( length*2+1 );
int size = 0;
size = WideCharToMultiByte( CP_ACP, 0, (LPCWSTR)jcstr, length, rtn,(length*2+1), NULL, NULL );
if( size <= 0 )
return NULL;
(env)->ReleaseStringChars(jstr, jcstr );
rtn[size] = 0;
return rtn;
}
//将windows类型转换成jstring类型
jstring WindowsTojstring( JNIEnv* env, char* str )
{
jstring rtn = 0;
int slen = strlen(str);
unsigned short * buffer = 0;
if( slen == 0 )
rtn = (env)->NewStringUTF(str );
else
{
int length = MultiByteToWideChar( CP_ACP, 0, (LPCSTR)str, slen, NULL, 0 );
buffer = (unsigned short *)malloc( length*2 + 1 );
if( MultiByteToWideChar( CP_ACP, 0, (LPCSTR)str, slen, (LPWSTR)buffer, length ) >0 )
rtn = (env)->NewString( (jchar*)buffer, length );
}
if( buffer )
free( buffer );
return rtn;
}
/*JNIEXPORT jstring JNICALL Java_test_cs_web_SWIFTAlianceCASmfTest_strcal
(JNIEnv *env, jclass obj, jstring jstr1, jstring jstr2)
{
jbyteArray bytes = 0;
jthrowable exc;
char *pszResult = NULL;    
char *pszSTR1 = NULL;
char *pszSTR2 = NULL;

pszSTR1 = jstringTostring(env, jstr1);
pszSTR2 = jstringTostring(env, jstr2);


int nlen = sizeof(char)*(strlen(pszSTR1)+strlen(pszSTR2));
pszResult = (char*)malloc(nlen);
strcpy(pszResult, pszSTR1);
strcat(pszResult, pszSTR2);

jstring jstrRe = stoJstring(env, pszResult);
free(pszSTR1);
free(pszSTR2);
free(pszResult);
return(jstrRe);
}
*/


jni object的使用

每一个jni格式的dll中的object对应该java里面的一个类。
如下例有一个 ObjData类,类中有成员bData ,Len 
public class ObjData {

public byte[]  bData; 
public int Len;        
}
//------------------------jni获得传过来的Object类型的变量objDataIn--------

jclass clazz =(env)->FindClass("ObjData"); 

//从传进来的对象中取出byte[]
jfieldID byteData = (env)->GetFieldID(clazz,"bData","[B");
jbyteArray pDataIn = (jbyteArray) (env)->GetObjectField(objDataIn, byteData);
jsize theArrayLeng = env->GetArrayLength(pDataIn);

//byte[]转为BYTE[]
jbyte * arrayBody = env->GetByteArrayElements(pDataIn,0); 
BYTE * jDataIn = (BYTE *)arrayBody; 


//将BYTE数组转为jarray
jbyte* byte = (jbyte*)jDataOut;    
jbyteArray jarray = env->NewByteArray(theArrayLeng);
env->SetByteArrayRegion(jarray, 0, theArrayLeng, byte);

//给每一个实例的变量付值
(env)->SetObjectField(objDataIn,byteData,jarray);
(env)->SetIntField(objDataIn,pDataInLen,jDataInLen);

(env)->ReleaseByteArrayElements(pDataIn, arrayBody, 0);




.....
有时间可以研究下jni.h源代码
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值