android studio JNI开发
一、JNI的作用:
使Java与本地其他类型语言(C、C++)交互;
在Java代码调用C、C++等语言的代码 或者 C、C++调用Java代码。
由于JAVA具有跨平台的特点,所以JAVA与本地代码的交互能力弱,采用JNI特性可以增强JAVA与本地代码的交互能力。
二、AndroidStudion中JNI的使用方法:
在AS,点击File ->Setting,下载NDK 和 CMake。
2、配置环境变量:
path中添加环境变量:C:\Users\a\AppData\Local\Android\Sdk\ndk\26.0.10404224\build(我的环境)。
配置的是NDK在系统里安装的位置。
三、测试demo:
新建一个工程JNITest,在工程的包名下,新建一个JAVA类,类名为JNITest:
package com.example.myapplication;public class JNITest { public native String getJNIString();}
使用javac命令编译JNITest.java文件,生成JNITest.class文件。
在工程目录下执行如下命令:javac .\JNITest.java
执行完毕后可以看到包名下面生成了对应的class文件,如下图所示:
3. 生成JNITest.class文件后,需要生成对应的.h文件:
在工程目录下执行如下命令:javah -d app/class="lazy" data-src/main/jni -classpath app/class="lazy" data-src/main/java/ -jni -v com.example.myapplication.JNITest
执行完毕后可以看到在app/class="lazy" data-src/main目录下生成了jni目录,目录里生成了对应的.h文件,文件名为com_example_myapplication_JNITest.h
在jni目录下,新建一个cpp文件,命名为JNITest.cpp,文件里实现JNITest.java文件里定义的本地方法:
右击jni->New->C/C++ Source File->输入JNITest
JNITest.cpp 文件代码:
#include #include "JNITest.h"JNIEXPORT jstring JNICALL Java_com_example_myapplication_JNITest_getJNIString (JNIEnv* env, jobject){ return env->NewStringUTF("Hello From JNITest Function(getJNIString)");}
com_example_myapplication_JNITest.h 文件代码:
#include #ifndef _Included_com_example_myapplication_JNITest#define _Included_com_example_myapplication_JNITest#ifdef __cplusplusextern "C" {#endifJNIEXPORT jstring JNICALL Java_com_example_myapplication_JNITest_getJNIString (JNIEnv *, jobject){ { return env->NewStringUTF("Hello From JNITest Function(getJNIString)"); } };#ifdef __cplusplus}#endif#endif
在jni目录下,再新建一个Android.mk文件:
右击jni目录->New->File->输入Android.mk,在文件里写入如下配置:
LOCAL_PATH := $(call my-dir)include $(CLEAR_VARS)LOCAL_MODULE := JNITestLOCAL_class="lazy" data-src_FILES := JNITest.cppinclude $(BUILD_SHARED_LIBRARY)
再新建文件夹:Application.mk,写入配置:
APP_PLATFORM := android-21APP_ALLOW_MISSING_DEPS=true
在终端进入到项目"app/class="lazy" data-src/main/jni"目录下,执行ndk-build,执行后在app/class="lazy" data-src/main目录下自动生成lib文件夹,生成好的so库文件就在lib文件夹下,如下图所示:
免责声明:
① 本站未注明“稿件来源”的信息均来自网络整理。其文字、图片和音视频稿件的所属权归原作者所有。本站收集整理出于非商业性的教育和科研之目的,并不意味着本站赞同其观点或证实其内容的真实性。仅作为临时的测试数据,供内部测试之用。本站并未授权任何人以任何方式主动获取本站任何信息。
② 本站未注明“稿件来源”的临时测试数据将在测试完成后最终做删除处理。有问题或投稿请发送至: 邮箱/279061341@qq.com QQ/279061341