利用Android studio开发JNI工程

简要介绍下自己在利用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 __cplusplus
extern "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库
        }
    }


4.在MainActivity中加载库文件

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
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值