Android Studio制作.so库实践

前言

因为工作需要可能要用到JNI开发,本篇文章就分享一下我在这方面的实践,以前我们使用Eclipse做NDK开发,非常麻烦,需要配cygwin的编译环境,后面NDK功能完善才逐渐简单点,如果想了解Eclipse如何配置NDK编译环境可以参考我以前发表的旧文:

Cocos2d-x 2.2.3 使用NDK配置编译环境

JNI_Android项目中调用.so动态库

Eclipse的如何通过NDK生成so库就不多说了,目前已经不适用于Android开发,建议使用AS进行开发,本篇也是基于AS来进行讲解。

什么是JNI

如果你进行Android开发一段时间还不知道什么是JNI的话,说明你还是初学者,没有理解Java层跟Native层之间是如何交互的。JNI(Java Native Interface的缩写),Java层通过JNI来调用Native层的功能模块,这样做的好处是能消除平台的差异性,避免重复制造轮子。Java的跨平台性也体现在这里。

如何通过JNI调用Native层的c/c++代码,可以参考我的一篇文章:

JNI_最简单的Java调用C/C++代码

注:window的动态库是.dll文件,而Linux下的动态库是.so文件

配置NDK

如果翻不了墙,可以到这里下载相应平台的NDK版本

http://www.androiddevtools.cn/

下载成功之后解压缩,然后配置系统环境变量,拿windows举例:

先新建NDK_HOME

然后再添加到PATH环境变量中

ok,配好之后,直接可以在命令行使用ndk-build命令:

这里提示没有定义NDK_PROJECT_PATH变量,暂且不管,我们后面说。

然后,在Android Studio配置NDK路径:

上面是笔者的路径,具体按你们来配。

至此,NDK环境配置完毕。

定义Native方法

这里创建一个Android项目-JNIDemo,然后定义TestJNI类,代码如下:

package com.devilwwj.jnidemo;

/**
 * Created by wwj_748 on 2016/4/27.15.47
 */
public class TestJNI {
    public native boolean Init();
    public native int Add(int x, int y);
    public native void destory();
}

使用javah命令生成.h文件

执行完上面的命令之后,就生成了com_devilwwj_jnidemo_TestJNI.h这个文件:

ok,这样我们就可以进行下一步操作了。

创建jni目录,创建.cpp文件

然后根据.h文件,创建相对应的.cpp文件

com_devilwwj_jnidemo_TestJNI.cpp

//
// Created by wwj_748 on 2016/4/27.
//
#include <stdio.h>
#include <stdlib.h>
#include "com_devilwwj_jnidemo_TestJNI.h"
#include "Add.h"

CAdd *pCAdd = NULL;

JNIEXPORT jboolean JNICALL Java_com_devilwwj_jnidemo_TestJNI_Init(JNIEnv *env, jobject obj) {
  if (pCAdd == NULL) {
    pCAdd = new CAdd;
  }
  return pCAdd != NULL;
  }

JNIEXPORT jint JNICALL Java_com_devilwwj_jnidemo_TestJNI_Add
  (JNIEnv *env, jobject obj, jint x, jint y) {
    int res = -1;
    if (pCAdd != NULL) {
        res = pCAdd->Add(x, y);
    }
    return res;
  }

  JNIEXPORT void JNICALL Java_com_devilwwj_jnidemo_TestJNI_destory
    (JNIEnv *env, jobject obj) {
    if (pCAdd != NULL) {
        pCAdd = NULL;
    }
    }

这里我还需要创建两个文件,CAdd.h和CAdd.cpp:

ok,到目前我们已经完成JNI层的实现了。

创建Android.mk和Application.mk文件

在jni目录下,我们需要创建两个mk文件

Android.mk

LOCAL_PATH := $(call my-dir)
include $(CLEAR_VARS)

LOCAL_MODULE := JNIDemo
LOCAL_SRC_FILES := com_devilwwj_jnidemo_TestJNI.cpp
LOCAL_SRC_FILES += Add.cpp

include $(BUILD_SHARED_LIBRARY)

其中LOCAL_PATH是C/C++代码所在目录,也就是我们的jni目录。

LOCAL_MODULE是要编译的库的名称。编译器会自动在前面加上lib,在后面加上.so。

LOCAL_SRC_FILES是要编译的C/C++文件。

Application.mk

APP_ABI := all

表示生成所有平台的动态库。

配置gradle

在defaultConfig下,配置ndk:

 ndk {
            moduleName "JNIDemo" // 生成的so名字
        }

在android标签内配置sourceSets:

 sourceSets {
        main {
            jniLibs.srcDirs = [‘libs‘]
        }
    }

生成的so文件都在src/main/libs目录下。

完整的gradle配置,可以看源码。

执行ndk-build命令生成所有cpu架构的so库

然后就可以在libs目录下看到所有平台的so库:

至此,完整的so库实践基本完毕,期间遇到任何问题均可留言,欢迎讨论交流。

最后

关于NDK开发so库会有很多坑,本篇博客也只是引大家入门,我们在使用第三方的SDK的时候,就可能会用到别人提供的so库,也可能会遇到使用so库出现问题,有很多原因,可能是提供了不同的cpu架构的so库,在其他平台出现的crash或者是其他问题,相信我们会遇到的问题别人也会遇到,这时候google一下也许能找到解决方案,最后祝生活愉快。



欢迎关注我的公众号:wwjblog

时间: 2024-10-26 15:48:03

Android Studio制作.so库实践的相关文章

android studio 导入第三方库的记录

转载请标明出处: http://blog.csdn.net/lxk_1993/article/details/50493582 android studio 导入第三方库的记录.jar包 和 库 一.jar包 1.jar包的话非常easy,首先换成project模式.将你要用的jar包拷贝到lib以下.如图 2.然后右键选择Add as libary(多个jar也仅仅要随便选一个就这样加入就好了). 3.或者按住 shirt + ctrl + alt + s,然后按图所看到的选择文件加入. 二.

Android Studio 制作出来的9图无法进行拖拉,导致无法制作出正确的9图

使用Android Studio制作,但发现无法进行拖拽,无法制作正确的9图,如下所示: 这几根线无法拖拽. 经分析得知,原来是png图片的问题,原本的图片是8位的png图片,这样子制作出来的9图就是无法拖拽的.  如何解决?--> 获取32位的png图片即可. 方式1:可以让UI提供32位的png图片,16位的png图片也不行,需要32位的. 方式2:自己将8位的png图片转成32位的. 使用画图3D打开: 然后另存为 转出来的图片就是32位的: 然后就可以制作出可以拖拽的9图了. 原文地址:

Android Studio Git 分支使用实践

新公司有些项目是用的 Git,以前公司都是 svn,为了练手 Git,我个人 APP 用到了,但是仅简单的 git pull/push 的使用,并未用到 Git 精髓,只有当项目中用到,才会紧迫去全面学习,所以说,在项目中进步是最快的. 开发场景:远程有主分支 master,提供用户使用的正式的稳定的版本:开发分支 dev,用于日常开发.dev 们可以在本地任意创建自己的 Local Branch,然后合并到本地 master 再提交到远程分支 dev. 命令行实践 高手都是直接用命令行,用命令

android studio引入so库方法

在Android Studio中引入so库,只需在app/jniLibs下放入so文件,然后在Module的build.gradle中加入: sourceSets { main { jniLibs.srcDirs = ['libs'] } } 完整的build.gradle如下: apply plugin: 'com.android.library' android { compileSdkVersion 23 buildToolsVersion "23.0.2" defaultCon

Android Studio导入第三方库(SlidingMenu)教程

搞了半天,android的初学者,看着网上各种例子,特此记录. 注意:本教程针对像SlidingMenu这样使用Android Studio结构的第三方库. 开始: 第一步,去GitHub下载SlidingMenu (下载地址:https://github.com/jfeinstein10/SlidingMenu),下载下来在你的电脑上应该是这样样子的: 第二步,建立一个Android Studio项目: 第三步,在咱们的SlidingMenudemo项目里建立个model,这样就避免了好多教程

android studio 导入第三方库的方法

今天在导入第三方库的时候发生了一系列的错误,记录一下经验吧. 1.现将第三方*.jar或 *.aar包放到项目中的/app/libs 目录下.然后修改项目的 2.修改project 的build.gradle在 allprojects =>repositories 中添加如下,来设置导入目录 /***Adds an configures a repository which will look for dependencies in a number of local directories.*

使用Android Studio导入第三方库项目

在使用Android Studio开发时,用到了第三方库SlidingMenu(现在已经不推荐使用了),尽管如此,但具体怎么导入第三方库还是需要知道的,在查阅各种资料后,知道了一种比较容易可行的方法 具体步骤如下 1.首先,需要从GitHub上下载去SlidingMenu (https://github.com/jfeinstein10/SlidingMenu) 2.接下来在你的项目上右击New->Module(这样避免了修改gradle的繁琐步骤),然后选择Android Library 3.

android ndk-build 编译静态库libxx.a 以及Android studio openssl 静态库配置(cmake)

android ndk-build 编译静态库libxx.a 需求场景: 目前有安卓编码好的现在的openssl的两个.a,我们需要调用openssl的函数,并把功能再封装成.a; 这样使用时,在android studio jni项目 cmake 里面,需要先引用openssl的.a再引用 上面封装的.a; 如果使用so,那么,直接在android studio jni项目的 cpp里面直接调用openssl的方法,对外提供jni java接口,打包成so即可: 先来说用ndk-build 打

Android NDK——使用Android Studio引用so库,jar包及module并使用JNI的正确姿势

引言 由于项目中需要用到JNI,以前虽然在Eclipse上使用过JNI和SO 文件,移植到Android Studio上的时候是花费好些力气的,也处理过不少常见的错误,而且网上很多文章都是只写了大致的步骤,忽略了很多细节,为了让新手们少走弯路,同时也是加强自己的理解,把自己一步一步的操作记录下来. 一.Android studio引入jar 不同于eclipse的配置build path,Android Studio可以通过图形界面Project Structure来配置dependencies