超级简单的Android Studio jni 实现(无需命令行)

基本参看他文:超级简单的Android Studio jni实现
本人写了一个串口通讯的实例,可以下载下来看一下具体的代码jni实例

1.配置AndroidStudio环境:

  • javah
  • ndk-build
  • ndk-build clean

    其实就是配置命令,最后直接执行tools中的配置好的命令就OK,不用敲命令行
    当然事先请在androiddeveloper 中下载用户对应版本的ndk即可NDK下载
    这里写图片描述
    这里写图片描述

这里写图片描述

这里写图片描述

2.配置完成就可以使用javah 、ndk-build、ndk-build clean这三个命令了,那么在哪里使用这些命令,请看下图
这里写图片描述

3.配置完成,我们开始新建工程MyNdk,然后新建jni目录
这里写图片描述

4.修改app下的build.gradle文件, 如下图

ndk{    
  moduleName "MyLibrary"
}
sourceSets.main{
    jni.srcDirs = []    
    jniLibs.srcDir "src/main/libs"
}

这里写图片描述

5.修改MyNdk下的gradle.properties文件(如果没有此文件,自己新建一个),如下图

android.useDeprecatedNdk=true

这里写图片描述

6.新建MyNdk.java

public class MyNdk {
    static {
        System.loadLibrary("MyLibrary");    
}   
    public native String getString();
}

这里写图片描述

7.这步开始创建头文件,操作如下图(注意在MyNdk.java文件上点击右键)

这里写图片描述

8.执行完成后jni目录下就创建了com_zhangyp_higo_myndk_MyNdk.h文件,然后我们在jni目录下编写 MyLibrary.cpp、Android.mk、Application.mk这三个文件,代码如下:

这里写图片描述

com_zhangyp_higo_myndk_MyNdk.h

/* DO NOT EDIT THIS FILE - it is machine generated */
#include <jni.h>
/* Header for class com_zhangyp_higo_myndk_MyNdk */

#ifndef _Included_com_zhangyp_higo_myndk_MyNdk
#define _Included_com_zhangyp_higo_myndk_MyNdk
#ifdef __cplusplus
extern "C" {
#endif
/*
 * Class:     com_zhangyp_higo_myndk_MyNdk
 * Method:    getString
 * Signature: ()Ljava/lang/String;
 */
JNIEXPORT jstring JNICALL Java_com_zhangyp_higo_myndk_MyNdk_getString
  (JNIEnv *, jobject);

#ifdef __cplusplus
}
#endif
#endif
MyLibrary.cpp
#include "com_zhangyp_higo_myndk_MyNdk.h"

JNIEXPORT jstring JNICALL Java_com_zhangyp_higo_myndk_MyNdk_getString
  (JNIEnv * env, jobject obj){
   return (*env).NewStringUTF("This is mylibrary !!!");
  }
Android.mk
LOCAL_PATH := $(call my-dir)

include $(CLEAR_VARS)

LOCAL_MODULE := MyLibrary
LOCAL_SRC_FILES =: MyLibrary.cpp
include $(BUILD_SHARED_LIBRARY)
Application.mk
APP_MODULES := MyLibrary
APP_ABI := all

9.如何执行ndk-build,请看下图:(注意在jni目录上点击右键)
这里写图片描述

10.得到so文件,如下图
这里写图片描述

11.在MainActivity中调用,代码如下:

public class MainActivity extends AppCompatActivity {

    @Override
    protected void onCreate(Bundle savedInstanceState) {
        super.onCreate(savedInstanceState);
        setContentView(R.layout.activity_main);
        TextView tv = (TextView) findViewById(R.id.tv);

        tv.setText(new MyNdk().getString());

    }
}

大公告成!

  • 0
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
JNI(Java Native Interface)是一种允许Java代码与本地代码(如C或C++)交互的编程桥梁。在Android Studio中使用JNI可以调用本地代码来实现一些高性能的功能或访问底层系统资源。 要在Android Studio中使用JNI,首先需要创建一个JNI接口文件(.h),该文件将定义Java和本地代码之间的函数接口。然后,使用ndk-build工具或CMake配置来构建本地代码库。 下面是一个简单的步骤来使用JNI: 1. 在Android Studio项目中,创建一个名为"jni"的文件夹,并在其中创建一个名为"native-lib.cpp"的C++源文件。 2. 在native-lib.cpp中实现自己的本地函数,可以通过JNI调用这些函数。 ```cpp #include <jni.h> extern "C" JNIEXPORT jstring JNICALL Java_com_example_myapp_MainActivity_getMessageFromJNI(JNIEnv* env, jobject /* this */) { return env->NewStringUTF("Hello from JNI!"); } ``` 3. 在项目的build.gradle文件中,添加NDK配置。 ```groovy android { // ... defaultConfig { // ... externalNativeBuild { cmake { cppFlags "" } } } // ... externalNativeBuild { cmake { path "CMakeLists.txt" } } } ``` 4. 在项目根目录下创建一个名为"CMakeLists.txt"的文件,并设置构建本地代码的相关设置。 ```cmake cmake_minimum_required(VERSION 3.4.1) add_library(native-lib SHARED native-lib.cpp) find_library(log-lib log) target_link_libraries(native-lib ${log-lib}) ``` 5. 在MainActivity.java中,加载本地库并调用本地函数。 ```java public class MainActivity extends AppCompatActivity { static { System.loadLibrary("native-lib"); } // ... public native String getMessageFromJNI(); // ... @Override protected void onCreate(Bundle savedInstanceState) { super.onCreate(savedInstanceState); setContentView(R.layout.activity_main); // 调用本地函数 String message = getMessageFromJNI(); Log.d("JNI", message); } } ``` 这样就可以在Android Studio中使用JNI来调用本地代码了。需要注意的是,使用JNI需要熟悉C/C++编程,并且需要手动管理Java和本地代码之间的内存和类型转换。

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值