java jni 参数_JNI各类型参数互相调用示例(二)

本文介绍了Java JNI中如何进行字符串和字节数组的相互转换,包括Java字符串到C/C++的转换,C/C++到Java字符串的转换,以及字节数组与C++中BYTE数组的互转。示例代码详细展示了各种转换方法,如GetStringUTFChars, NewStringUTF, GetByteArrayElements等函数的使用。" 108728502,1864781,Docker 自定义 Bridge 网络详解,"['Docker 容器', 'Docker 生态', 'Kubernetes', '网络配置']
摘要由CSDN通过智能技术生成

jni和java之间字符串的转换方法。C的实现:JNIEXPORT

jstring JNICALL Java_Android123_CwjC (JNIEnv *env, jobject obj,

jstring string){char

szBuffer[255];return

(*env)->NewStringUTF(env, szBuffer);}C++的实现:JNIEXPORT

jstring JNICALL Java_Android123_CwjCpp (JNIEnv *env, jobject obj,

jstring string){const

char *strUTF = env->GetStringUTFChars(string,

0);char

szBuffer[255];strcpy(szBuffer,

strUTF);env->ReleaseStringUTFChars(string,

strUTF);return

env->NewStringUTF(szBuffer);}

java中string与byte[]的转换

1.string 转 byte[]

byte[]

midbytes=isoString.getBytes("UTF8");

//为UTF8编码

byte[]

isoret = srt2.getBytes("ISO-8859-1");

//为ISO-8859-1编码

其中ISO-8859-1为单字节的编码

2.byte[]转string

String

isoString = new String(bytes,"ISO-8859-1");

String

srt2=new String(midbytes,"UTF-8");

//jbytearray转c++byte数组

jbyte * arrayBody =

env->GetByteArrayElements(data,0);

3

jsize theArrayLengthJ = env->GetArrayLength(data);

4

BYTE * starter = (BYTE *)arrayBody;

1

//jbyteArray 转 c++中的BYTE[]

2

//jbytearray array

3

jbyte * olddata = (jbyte*)env->GetByteArrayElements(array,

0);

4

jsize oldsize =

env->GetArrayLength(array);

5

BYTE* bytearr = (BYTE*)olddata;

6

int len = (int)oldsize;

1

//C++中的BYTE[]转jbyteArray

2

//nOutSize是BYTE数组的长度

BYTE pData[]

3

jbyte *by = (jbyte*)pData;

4

jbyteArray jarray = env->NewByteArray(nOutSize);

5

env->SetByteArrayRegin(jarray, 0, nOutSize, by);

1

//jbyteArray 转 char *

2

char* data = (char*)env->GetByteArrayElements(strIn,

0);

1

//char* 转jstring

2

jstring WindowsTojstring(JNIEnv* env, char* str_tmp)

3

{

4

jstring

rtn=0;

5

int

slen = (int)strlen(str_tmp);

6

unsigned

short* buffer=0;

7

if(slen

== 0)

8

{

9

rtn

= env->NewStringUTF(str_tmp);

10

}

11

else

12

{

13

int

length = MultiByteToWideChar(CP_ACP, 0, (LPCSTR)str_tmp, slen,

NULL, 0);

14

buffer

= (unsigned short*)malloc(length*2+1);

15

if(MultiByteToWideChar(CP_ACP,

0, (LPCSTR)str_tmp, slen, (LPWSTR)buffer, length) >

0)

16

{

17

rtn

= env->NewString((jchar*)buffer, length);

18

}

19

}

20

if(buffer)

21

{

22

free(buffer);

23

}

24

return

rtn;

25

}

1

//jstring 转 char* 或者 const

char*

2

// jstring str

3

const char *key = env->GetStringUTFChars(str, 0);

4

//jboolean isOffer

5

jsClient->modify(key, isOffer);

6

//需要释放,否则容易内存泄露

7

env->ReleaseStringUTFChars(str, key);

1

//JNI 返回 jbyteArray

2

JNIEXPORT jbyteArray JNICALL Java_Test_getByteArray(JNIEnv *env,

jobject obj)

3

{

4

jbyteArray

firstMacArray = env->NewByteArray( 6 );

5

......

6

jbyte

*bytes = env->GetByteArrayElements( firstMacArray,

0);

7

for

( int i = 0; i < sizeof( pAdapterInfo->Address ); i++ )

8

{

9

bytes[

i ] = pAdapterInfo->Address[ i ];

10

}

11

12

env->SetByteArrayRegion(firstMacArray,

0, 6, bytes );

13

return

firstMacArray;

14

}

1

//jstring to char*

2

char* jstringTostring(JNIEnv* env, jstring jstr)

3

{

4

char*

rtn = NULL;

5

jclass

clsstring = env->FindClass("java/lang/String");

6

jstring

strencode = env->NewStringUTF("utf-8");

7

jmethodID

mid = env->GetMethodID(clsstring, "getBytes",

"(Ljava/lang/String;)[B");

8

jbyteArray

barr= (jbyteArray)env->CallObjectMethod(jstr, mid,

strencode);

9

jsize

alen = env->GetArrayLength(barr);

10

jbyte*

ba = env->GetByteArrayElements(barr, JNI_FALSE);

11

if

(alen > 0)

12

{

13

rtn

= (char*)malloc(alen + 1);

14

memcpy(rtn,

ba, alen);

15

rtn[alen]

= 0;

16

}

17

env->ReleaseByteArrayElements(barr,

ba, 0);

18

return

rtn;

19

}

1

char* to jstring

2

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

3

{

4

jclass

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

5

jmethodID

ctorID = env->GetMethodID(strClass, "",

"([BLjava/lang/String;)V");

6

jbyteArray

bytes = env->NewByteArray(strlen(pat));

7

env->SetByteArrayRegion(bytes,

0, strlen(pat), (jbyte*)pat);

8

jstring

encoding = env->NewStringUTF("utf-8");

9

return

(jstring)env->NewObject(strClass, ctorID, bytes,

encoding);

10

}

1

//将jstring类型转换成windows类型

2

char* jstringToWindows( JNIEnv *env, jstring jstr )

3

{

4

int

length = (env)->GetStringLength(jstr );

5

const

jchar* jcstr = (env)->GetStringChars(jstr, 0 );

6

char*

rtn = (char*)malloc( length*2+1 );

7

int

size = 0;

8

size

= WideCharToMultiByte( CP_ACP, 0, (LPCWSTR)jcstr, length,

rtn,(length*2+1), NULL, NULL );

9

if(

size <= 0 )

10

return

NULL;

11

(env)->ReleaseStringChars(jstr,

jcstr );

12

rtn[size]

= 0;

13

return

rtn;

14

}

1

//将windows类型转换成jstring类型

2

jstring WindowsTojstring( JNIEnv* env, char* str )

3

{

4

jstring

rtn = 0;

5

int

slen = strlen(str);

6

unsigned

short * buffer = 0;

7

if(

slen == 0 )

8

rtn

= (env)->NewStringUTF(str );

9

else

10

{

11

int

length = MultiByteToWideChar( CP_ACP, 0, (LPCSTR)str, slen, NULL, 0

);

12

buffer

= (unsigned short *)malloc( length*2 + 1 );

13

if(

MultiByteToWideChar( CP_ACP, 0, (LPCSTR)str, slen, (LPWSTR)buffer,

length ) >0 )

14

rtn

= (env)->NewString( (jchar*)buffer, length );

15

}

16

if(

buffer )

17

free(

buffer );

18

return

rtn;

19

}

20

1

//从传进来的对象中取出byte[]

2

jfieldID byteData =

(env)->GetFieldID(clazz,"bData","[B");

3

jbyteArray pDataIn = (jbyteArray)

(env)->GetObjectField(objDataIn, byteData);

4

jsize theArrayLeng = env->GetArrayLength(pDataIn);

1

//byte[]转为BYTE[]

2

jbyte * arrayBody =

env->GetByteArrayElements(pDataIn,0);

3

BYTE * jDataIn = (BYTE *)arrayBody;

JNI开发交流 C/C++,JAVA,android,linux/unixQQ群:25093009

1

//将BYTE数组转为jarray

2

jbyte* byte =

(jbyte*)jDataOut;

3

jbyteArray jarray = env->NewByteArray(theArrayLeng);

4

env->SetByteArrayRegion(jarray, 0, theArrayLeng,

byte);

1

//给每一个实例的变量付值

2

(env)->SetObjectField(objDataIn,byteData,jarray);

3

(env)->SetIntField(objDataIn,pDataInLen,jDataInLen);

4

(env)->ReleaseByteArrayElements(pDataIn, arrayBody,

0);

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值