利用Android studio开发JNI工程
来源:互联网 发布:万国数据科技公司电话 编辑:程序博客网 时间:2024/05/16 14:01
简要介绍下自己在利用Android Studio开发JNI时的步骤和遇到的问题
1.创建一个Android工程,在MainActivity里面定义一个native方法,如下:
public native String stringFromJNI();
2.执行Build->Make Project生存MainActivity的class文件
在studio的Terminal的窗口进入到“app/src/main”目录下面,执行下面的命令就可以生成对应的.h文件
javah -d jni -classpath ../../build/intermediates/classes/debug acitvity.jason.com.jnidemo1.MainActivity
编写自己的.c文件,主要功能是返回一个String,如下
/* DO NOT EDIT THIS FILE - it is machine generated */#include <jni.h>#include <android/log.h>/* Header for class acitvity_jason_com_jnidemo1_MainActivity */#ifndef _Included_acitvity_jason_com_jnidemo1_MainActivity#define _Included_acitvity_jason_com_jnidemo1_MainActivity#ifdef __cplusplusextern "C" {#endif/* * Class: acitvity_jason_com_jnidemo1_MainActivity * Method: stringFromJNI * Signature: ()Ljava/lang/String; */JNIEXPORT jstring JNICALL Java_acitvity_jason_com_jnidemo1_MainActivity_stringFromJNI (JNIEnv *env, jobject jobject){ return (*env)->NewStringUTF(env, "Hello From JNI!");}#ifdef __cplusplus}#endif#endif
3.在项目中配置ndk环境
在 local.properties 文件中设置ndk的路径:
ndk.dir=your_path/android-ndk-r10e在app目录下的 build.gradle中设置库文件名(生成的so文件名),在defaultConfig分支中增加上
defaultConfig { applicationId "acitvity.jason.com.jnidemo1" minSdkVersion 11 targetSdkVersion 22 versionCode 1 versionName "1.0" ndk{ moduleName "hello-jni"//配置生成的so库名称 abiFilters "armeabi", "armeabi-v7a", "x86" //指定三种abi体系结构下的so库 } }
static { System.loadLibrary("hello-jni"); }运行截图如下
5.使用__android_log_print输出Log
在hello-jni.c文件中添加如下代码
#ifndef LOG_TAG#define LOG_TAG "ANDROID_LAB"#define LOGE(...) __android_log_print(ANDROID_LOG_ERROR, LOG_TAG, __VA_ARGS__)#endif
在需要打印日志的地方调用LOGE
JNIEXPORT jstring JNICALL Java_acitvity_jason_com_jnidemo1_MainActivity_stringFromJNI (JNIEnv *env, jobject jobject){ LOGE("log string from ndk"); return (*env)->NewStringUTF(env, "Hello From JNI!");}
这样编译的话会报错: undefined reference to `__android_log_print
需要在app/build.gradle的defaultConfig分支里修改NDK的配置如下
ndk{ moduleName "hello-jni" //配置生成的so库名称 ldLibs "log"//实现__android_log_print abiFilters "armeabi", "armeabi-v7a", "x86" //指定三种abi体系结构下的so库 }这样运行就能打印出我们自己加的log了,如有需要,源代码上传到scdn上,你可以自己下载
0 0
- 利用Android studio开发JNI工程
- Android Studio开发JNI工程
- Android Studio开发JNI工程
- Android Studio开发JNI工程
- Android Studio开发JNI工程
- Android Studio开发JNI工程
- Android Studio开发JNI工程
- Android Studio开发JNI工程
- Android Studio开发JNI工程
- Android Studio开发JNI工程
- Android Studio开发JNI工程
- Android Studio开发JNI工程
- Android Studio开发JNI工程
- Android Studio开发JNI工程
- Android Studio 开发JNI工程步骤
- Android Studio上面使用Ndk JNI 开发工程
- Android Studio新建jni工程
- Android Studio开发JNI
- AFNetWork中断单个多个全部请求的方法
- zookeeper伪分布式集群环境搭建
- 有符号和无符号整型数据溢出问题
- 我爱智慧石!分享咯~
- 关于黑客公司被黑,这些隐情需要知道
- 利用Android studio开发JNI工程
- error C2027: use of undefined type 'A' see declaration of 'A'
- IOS后台运行 之 后台播放音乐
- iOS入门(十四)函数指针
- 关于Python的super用法研究
- gcc/g++使用简介
- 动态规划之 最优二叉搜索数 递归实现
- hdoj 1875 畅通工程再续 【最小生成树】
- UNIX网络编程卷一:第十一章 名字与地址转换