JNI中C和java传递数组

本文深入探讨了如何在Java应用中利用C++实现JNI技术,通过Native.c和Android.mk文件实现Java与C++的交互。重点介绍了如何在Java环境中调用C++编写的本地函数,以及在C++环境中如何操作Java对象。详细步骤包括初始化环境、定义本地函数、加载库等关键步骤。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

MainActivity

package com.example.arraydeliver;

import android.app.Activity;
import android.app.ActionBar;
import android.app.Fragment;
import android.os.Bundle;
import android.util.Log;
import android.view.LayoutInflater;
import android.view.Menu;
import android.view.MenuItem;
import android.view.View;
import android.view.ViewGroup;
import android.widget.TextView;
import android.os.Build;

public class MainActivity extends Activity {
		byte[] a=new byte[]{0x32,0x33,0x34,'\0'};

	@Override
	protected void onCreate(Bundle savedInstanceState) {
		super.onCreate(savedInstanceState);
		setContentView(R.layout.activity_main);
		TextView tv= new TextView(this);
		tv.setText(stringFromJNI(a));
		setContentView(tv);
		
	}
	
	public native static String  stringFromJNI(byte[] a);
	
	static {
		System.loadLibrary("hello-jni");
	}
}
Native.c

#include <string.h>
#include <jni.h>
#include <stdlib.h>

typedef unsigned char byte;

JNIEXPORT jstring JNICALL Java_com_example_arraydeliver_MainActivity_stringFromJNI( JNIEnv* env,jobject thiz ,jbyteArray j){


	jbyte *temp=(*env)->GetByteArrayElements(env,j,0);
	char *x=(char *)temp;

	return (*env)->NewStringUTF(env,x+sizeof(x));

}


Android.mk


LOCAL_PATH := $(call my-dir)

include $(CLEAR_VARS)

LOCAL_MODULE    := hello-jni

LOCAL_SRC_FILES := Native.c

include $(BUILD_SHARED_LIBRARY)

注意:在Native.c中的GetByteArrayElements其实是获取java中的数组指针,所以在使用完后记得要释放(*env)->ReleaseByteArrayElements(env,j,temp,0)
注意2:C和C++中有些参数略有不同:C++中直接传入env->引用,C中则需要(×env)->,在C中jbyte *temp=(*env)->GetByteArrayElements(env,j,0);
     而在C++中则jbyte *temp=env->GetByteArrayElements(j,0);




评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值