Android使用jni调用c++/c方法详解

1、下载ndk

2、编写jni的加载类

参考例子:

public class JniTest {
 public native String append(String str1, String str2);
 static {
  System.loadLibrary("JniTest");
 }
}

以上append方法就是要调用c++/c中的方法。

JniTest是在Android.mk里约束好的,关于Android.mk的编写具体在后面详解。

3、使用javah -jni生成.h文件

编写好jni加载类之后,就要开始生成.h文件了,此文件相当于一个声明文件,起到jni连接c++源代码的桥梁作用(我猜的)。

具体步骤:

part1:编译项目,生成.class文件,打开android studio 的Terminal工具,cd 到app/build/intermediates/classes/debug目录下,输入命令

javah -jni 包名.JniTest

part2:然后你会看到app/build/intermediates/classes/debug目录下多出了一个(包名_JniTest.h)文件,将其拷贝到app/src/main/jni目录下,这一步就算完成了。

4、准备好c/c++源代码文件

参考例子:

#include <jni.h>
#include <malloc.h>
#include <string.h>

JNIEXPORT jstring JNICALL Java_com_dengdeng_dengdeng_test_JniTest_append
 (JNIEnv * env, jobject obj, jstring jstr1, jstring jstr2){
 const char *str1,*str2;
 char *result;
 int len1,len2;
 jstring jresult;
 str1 = (*env)->GetStringUTFChars(env,jstr1,NULL);
 str2 = (*env)->GetStringUTFChars(env,jstr2,NULL);
 len1 = strlen(str1);
 len2 = strlen(str2);
 result = malloc((len1+len2)*sizeof(char));
 strcpy(result,str1);
 strcpy(result+len1,str2);
 (*env)->ReleaseStringUTFChars(env,jstr1,str1);
 (*env)->ReleaseStringUTFChars(env,jstr2,str2);
 jresult = (*env)->NewStringUTF(env,result);
 free(result);
 return jresult;
}

将c/c++源码放入app/src/main/jni目录下即可。

5、编写Application.mk和Android.mk文件

参考例子:

Application.mk:

# 使用的ndk库函数版本号。一般和SDK的版本相对应,各个版本在NDK目录下的platforms文件夹中
APP_PLATFORM := android-14
# 编译成什么类型的cpu的so, 拥有三个属性armeabi armeabi-v7a x86可以全选 也可以只用一个,如果全选也可以使用all
APP_ABI :=all
APP_STL:=stlport_static

Android.mk:

LOCAL_PATH := $(call my-dir)
include $(CLEAR_VARS)
#需要修改输出.so文件的名字字段——本字段和上文的设置相对应。
LOCAL_MODULE := JniTest
#需要修改src文件名
LOCAL_SRC_FILES := jnitest.c
include $(BUILD_SHARED_LIBRARY)

以上两个文件存放至app/src/main/jni下,这一步就算完成了。

6、编写app.gradle

参考例子

ndk { //设置支持的SO库架构(开发者可以根据需要,选择一个或多个平台的so)
  abiFilters "armeabi", "armeabi-v7a", "x86","arm64-v8a", "arm64-v8a", "x86_64"
  moduleName "JniTest"
  ldLibs "EGL","GLESv3","dl","log"
}
sourceSets.main {
  jni.srcDirs = []//disable automatic ndk-build call
  jniLibs.srcDir "src/main/libs"
}

7、用ndk-build命令编译成so库

打开Terminal,cd到app/src/main/jni,输入命令:ndk-build即可生成对应的so,这一步比较简单,不做赘述。

8、android载入so并调用方法

参考例子:

JniTest jni = new JniTest();
String result = jni.append("abc", "123");

直接调用就可以了

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持我们。

(0)

相关推荐

  • Android JNI c/c++调用java的实例

    Android JNI c/c++调用java的实例 近期通过研究SDL源码 得出Android JNI  c/c++调用Java 无需新建虚拟机,这样省去很多步骤,这样调用Android JNI会变得非常容易,大家看下简单实例: 具体步骤如下 第一步获得:两个参数 JNIEnv和jclass void Java_com_Test_Audio_Init( JNIEnv* env,jclass cls, jobject thiz ) { InitJNI(env,cls); } bool InitJ

  • Android使用jni调用c++/c方法详解

    1.下载ndk 2.编写jni的加载类 参考例子: public class JniTest { public native String append(String str1, String str2); static { System.loadLibrary("JniTest"); } } 以上append方法就是要调用c++/c中的方法. JniTest是在Android.mk里约束好的,关于Android.mk的编写具体在后面详解. 3.使用javah -jni生成.h文件 编

  • Android适配底部虚拟按键的方法详解

    最近项目进行适配的时候发现部分(如华为手机)存在底部虚拟按键的手机会因为虚拟按键的存在导致挡住部分界面,因为需要全屏显示,故调用虚拟按键隐藏方法使之隐藏,然而发现出现如下问题: 手动操作隐藏虚拟按键后出现长白条区域 不自动隐藏 滑出状态栏后虚拟按键也出来,状态栏隐藏后虚拟却不跟着隐藏 在没有虚拟按键的设备上影响了SurfaceView全屏显示图传(原本全屏显示的图传在切出去再进来时变成了小屏显示) 通过google了很多方法并尝试终于解决了这个问题,达到如下效果: 每次进入界面时虚拟按键自动隐藏

  • Android程序打包为APK的方法详解

    Andriod安装包文件(Android Package),简称APK,后缀名为.apk. 1.生成未签名的安装包 Build -> Build Bundle(s)/APK(s) -> Build APK(s)    会生成一个未签名的apk文件,默认为debug版,可以正常安装使用. 可以 Build -> Select Build Variant -> 选择生成的apk版本(debug.release),再 Build -> Build Bundle(s)/APK(s)

  • Android 通过代码安装 APK的方法详解

    在 APK 开发中,通过 Java 代码来打开系统的安装程序以安装 APK 并不是什么难事,一般的 Android 系统都有开放这一功能. 但随着 Android系统版本的迭代,其对于权限的把控越来越严格,或者说是变得越来越注重安全性.这就导致了以前可以通过很简单的几行代码就能实现的功能,现在要复杂很多. 对于通过代码打开系统安装程序这一功能的限制,其分水岭在 Android7.0,即 Android N 上.通常在 Android N以上的系统使用一种做法,以下则使用另一种做法. 传统的通过代

  • Android学习之Span的使用方法详解

    目录 Span集合 段落类Span 其他Span 展示效果 小试牛刀 小结 Span集合 段落类Span BulletSpan 为段落开头增加项目符号并支持大小.颜色.弧度 span.append(SpannableString("BulletSpan").also { it.setSpan(BulletSpan(40, Color.RED), 0, 10, Spannable.SPAN_EXCLUSIVE_EXCLUSIVE) }) QuoteSpan 为段落开头增加垂直引用线 sp

  • 利用Android实现光影流动特效的方法详解

    目录 前言 MaskFilter 类简介 MaskFilter 的几种效果对比 光影流动 光影流动效果1 光影流动效果2 光影流动效果3 光影流动效果4:光影沿贝塞尔曲线流动 总结 前言 Flutter 的画笔类 Paint 提供了很多图形绘制的配置属性,来供我们绘制更丰富多彩的图形.前面几篇我们介绍了 shader 属性来绘制全屏渐变的聊天气泡背景.渐变流动的边框和毛玻璃效果的背景图片,具体可以参考下面几篇文章. 让你的聊天气泡丰富多彩! 手把手教你实现一个流动的渐变色边框 利用光影变化构建立

  • Android编程自定义AlertDialog样式的方法详解

    本文实例讲述了Android编程自定义AlertDialog样式的方法.分享给大家供大家参考,具体如下: 开发的时候,通常我们要自定义AlertDialog来满足我们的功能需求: 比如弹出对话框中可以输入信息,或者要展示且有选择功能的列表,或者要实现特定的UI风格等.那么我们可以通过以下方式来实现. 方法一:完全自定义AlertDialog的layout.如我们要实现有输入框的AlertDialog布局custom_dialog.xml: <?xml version="1.0"

  • Android编程解析XML文件的方法详解【基于XmlPullParser】

    本文实例讲述了Android编程解析XML文件的方法.分享给大家供大家参考,具体如下: 前言 在学习Android的Framework层源码时,Android大量的使用XmlPullParser来解析xml文件的源码.因此,这里也顺道介绍一下XmlPullParser的使用. XML XML(eXtensible Markup Language)中文名为可扩展标记语言.标记指计算机所能理解的信息符号,通过此种标记,计算机之间可以处理包含各种信息的文章等. 用途 XML设计用了传送及携带数据信息,

  • Android编程实现自定义手势的方法详解

    本文实例讲述了Android编程实现自定义手势的方法.分享给大家供大家参考,具体如下: 之前介绍过如何在Android程序中使用手势,主要是系统默认提供的几个手势,这次介绍一下如何自定义手势,以及如何对其进行管理. 先介绍一下Android系统对手势的管理,Android系统允许应用程序把用户的手势以文件的形式保存以前,以后要使用这些手势只需要加载这个手势库文件即可,同时Android系统还提供了诸如手势识别.查找及删除等的函数接口,具体如下: 一.加载手势库文件: staticGestureL

  • android编程之XML文件解析方法详解(附源码)

    本文实例讲述了android编程之XML文件解析方法.分享给大家供大家参考,具体如下: 在android开发中,经常用到去解析xml文件,常见的解析xml的方式有一下三种:SAX.Pull.Dom解析方式.最近做了一个android版的CSDN阅读器,用到了其中的两种(sax,pull),今天对android解析xml的这三种方式进行一次总结. 今天解析的xml示例(channels.xml)如下: <?xml version="1.0" encoding="utf-8

随机推荐