android studio c++ 代码提示,android studio NDK开发,简单调用C、C++

前言

之前一直都是使用别人写好的so文件,没有亲自去写过,于是决定研究一番。先说说NDK是什么呢?NDK其实就是一系列工具的集合。NDK有什么用呢?(1) NDK的发布,使“Java+C”的开发方式终于转正,成为官方支持的开发方式。(2)NDK将是Android平台支持C开发的开端。

环境配置

1. 在android studio中的setting-->Android SDK-->SDK Tools选项卡,下载NDK,CMake,LLDB三个工具

bb5124226528

QQ截图20170402094234.png

2. 新建一个项目,并勾选Include C++ support,一路next下去。

bb5124226528

QQ截图20170401171350.png

3. 配置android studio中ndk路径。如果ndk路径没有自动添加,则点击select即可。并在local.properties配置文件中检查是否正确配置路径。

bb5124226528

QQ截图20170402095009.png

bb5124226528

QQ截图20170402095059.png

4. 配置ndk系统环境变量,并在配置完成后检查配置是否成功

bb5124226528

QQ截图20170402095327.png

bb5124226528

QQ截图20170402095432.png

dos下命令:ndk-build;出现以下信息说明配置成功

bb5124226528

QQ截图20170402095704.png

5. 设置as。将ndk版本差异检测过滤掉,要不然项目无法编译。添加:android.useDeprecatedNdk=true

bb5124226528

QQ截图20170402095914.png

6. 编写调用c的java代码。注意:这里如果方法名报错,不用管他。同时把MainActivity里的 static {System.loadLibrary("native-lib"); }剪切复制到新建的MathKit类中

public class MathKit {

public static native int square(int num);

// Used to load the 'native-lib' library on application startup.

static {

System.loadLibrary("native-lib");

}

}

7. 生成调用本地方法的.h头文件。用as自带的Terminal工具来生成。

命令:

进入你项目的java文件夹下

cd app/src/main/java

com.axaet.ndk是你的完整包名,后面跟具体写有调用c代码的java类

javah -jni com.axaet.ndk.MathKit

bb5124226528

QQ截图20170402101250.png

bb5124226528

QQ截图20170402101337.png

8. 生成jni文件夹。用于存放.h和.c文件,把步骤7生成的.h头文件剪切到jni文件夹里,并创建对应的.c文件

bb5124226528

QQ截图20170402101858.png

bb5124226528

QQ截图20170402101747.png

9. 写c的测试代码。include中指向你创建的.h头文件 Java_com_axaet_ndk_MathKit_square;Java_包名类名方法名(参数)**

#include "com_axaet_ndk_MathKit.h"

//注意方法名要和.h文件里的一样

JNIEXPORT jint JNICALL Java_com_axaet_ndk_MathKit_square(JNIEnv *env, jclass cls, jint num) {

return num * num;

}

10.在build.gradle中配置生成so文件的信息,主要配置abiFilters

android {

compileSdkVersion 25

buildToolsVersion "25.0.2"

defaultConfig {

applicationId "com.axaet.ndk"

minSdkVersion 15

targetSdkVersion 25

versionCode 1

versionName "1.0"

testInstrumentationRunner "android.support.test.runner.AndroidJUnitRunner"

externalNativeBuild {

cmake {

cppFlags ""

abiFilters "armeabi-v7a", "armeabi", "x86"

}

}

}

buildTypes {

release {

minifyEnabled false

proguardFiles getDefaultProguardFile('proguard-android.txt'), 'proguard-rules.pro'

}

}

externalNativeBuild {

cmake {

path "CMakeLists.txt"

}

}

}

由于android studio 2.2以上使用CMake,所以需要配置CMakeLists.txt文件,修改生成后so文件名称、添加.c文件的路径

bb5124226528

QQ截图20170402102921.png

11. 用Make Project 生成so文件,然后运行项目。然后就可以拿到so文件

bb5124226528

QQ截图20170402103505.png

12. 测试本地c代码的调用。

public class MainActivity extends AppCompatActivity {

@Override

protected void onCreate(Bundle savedInstanceState) {

super.onCreate(savedInstanceState);

setContentView(R.layout.activity_main);

// Example of a call to a native method

TextView tv = (TextView) findViewById(R.id.sample_text);

//必须先加载so文件,加载so文件在MathKit类中

tv.setText(String.valueOf(MathKit.square(12)).concat(" ").concat(stringFromJNI()));

}

/**

* A native method that is implemented by the 'native-lib' native library,

* which is packaged with this application.

*/

public native String stringFromJNI();

}

下面是打包jar

13. 删除一些无用的资源,如MainActivity,layout等,只留下和JNI有关的java类

bb5124226528

QQ截图20170405154544.png

14. 修改module的build.gradle文件

有如下几个地方需要修改:

将最前面的apply plugin: 'com.android.application'修改为apply plugin: 'com.android.library'

将defaultConfig修改为:

defaultConfig {

minSdkVersion 14

targetSdkVersion 23

}

SDK的版本可以根据自己的版本来改

在最后加上

task deleteOldJar(type: Delete) {

delete 'build/outputs/test.jar'

}

task exportJar(type: Copy) {

from('build/intermediates/bundles/release/')

into('build/libs/')

include('classes.jar')

rename ('classes.jar', 'test.jar')

}

exportJar.dependsOn(deleteOldJar, build)

15.导出jar包

首先打开Gradle

bb5124226528

打开app->Tasks->other->exportJar

bb5124226528

然后双击exportJar就可以了,然后再'build/intermediates/bundles/release/'路径就可以找到classes.jar

当然混淆可以自己视情况添加。

项目源码

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

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值