Android开发笔记之Jni编程

在使用了Android studio之后,感觉实在是太方便了,在这记录一下其方便之一使用gradle-experimental构建一个JNI工程,在使用过程中遇到的坑,首先创建一个Android 工程MyJni,先看一下gradle/wrapper下的gradle-wrapper.properties这个文件,我这里默认是gradle-2.10-all.zip版本的
这里写图片描述

再看一下project下的build.gradle,需要修改默认的 classpath ‘com.android.tools.build:gradle:2.1.2’ 为 classpath ‘com.android.tools.build:gradle-experimental:0.7.0’,这里可参照http://tools.android.com/tech-docs/new-build-system/gradle-experimental这里的介绍, ,注意千万不要带有alpha1,虽然编译没问题,具体原因后文说明,如下图:
这里写图片描述

再次都app下的build.gradle,进行重新配置,箭头标红的地方都需要修改,那些版本设置中间都需要用等号赋值,这个一定要注意
这里写图片描述

    apply plugin: 'com.android.model.application'

    model {
    android {
        compileSdkVersion = 24
        buildToolsVersion = "24.0.0"

        defaultConfig.with {
            applicationId = "com.ly.myjni"
            minSdkVersion.apiLevel = 15
            targetSdkVersion.apiLevel = 24
            versionCode = 1
            versionName = "1.0"
        }
    }

    android.ndk {
        moduleName = "MyNdk"
        /*
         * Other ndk flags configurable here are
         * cppFlags.add("-fno-rtti")
         * cppFlags.add("-fno-exceptions")
         * ldLibs.addAll(["android", "log"])
         * stl       = "system"
         */
    }

    android.buildTypes {
        release {
            minifyEnabled = false
            proguardFiles.add(file('proguard-rules.txt'))
        }
    }
    android.productFlavors {
        create("arm") {
            ndk.abiFilters.add("armeabi")
        }
        create("arm7") {
            ndk.abiFilters.add("armeabi-v7a")
        }
        create("arm8") {
            ndk.abiFilters.add("arm64-v8a")
        }
        create("x86") {
            ndk.abiFilters.add("x86")
        }
        create("x86-64") {
            ndk.abiFilters.add("x86_64")
        }
        create("mips") {
            ndk.abiFilters.add("mips")
        }
        create("mips-64") {
            ndk.abiFilters.add("mips64")
        }
        // To include all cpu architectures, leaves abiFilters empty
        create("all")
    }
    }

    dependencies {
    compile fileTree(dir: 'libs', include: ['*.jar'])
    testCompile 'junit:junit:4.12'
    compile 'com.android.support:appcompat-v7:24.0.0'
    }

再次开始创建一个jni的目录,如下图所示:
这里写图片描述

在这随意创建一个调用本地方法即jni的类,注意这个类名和本地方法名不能使用’_’,否则生成jni方法会不成功

public class JniUtils {
static {
    System.loadLibrary("MyNdk");
}

public native String getStringFromC();
}

这里写图片描述

会在jni目录下自动生成MyNdk.c,修改returnValues,这个默认的方法是返回一个字符串
这里写图片描述

在这有些人就注意到了 ndk support is an experimental feature and all use cases are not yet supported,如果下面的jni没有报红的错误,说明的正确的,如果很多都报找不到jni.h的错误,这个是不影响编译的,编译可以成功,解决办法就是上面所说的gradle版本的问题,gradle-experimental:0.7.0这个一定要对应本地环境

使用gradle-experimental来进行Jni开发,有一个很好的好处就是Android.mk、Application.mk不用再谢了,而且编译也方便很多,还可以进行调试jni方法,可以打断点,进行调试,需要安装LLDB调试,具体过程,如果有需要下次再贴出来…

最后说明一下最后生产的.so会在这个目录MyJni\app\build\intermediates\binaries\debug\all\lib下

这个先写到这了,很少写,排版估计不好,见谅

资源下载

  • 2
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值