将cpp工程移植到android,android studio 將 cpp 文件編譯的so 庫 給其它工程使用

以下是我的運行環境:

操作系統:Ubuntu 16.0.4

IDE:Android Studio 3.0. beta4

網上大多數是另一種打包的流程,個人感覺比較麻煩,所以記錄下自己嘗試的這兩種

這兩種的前提都要有 ndk 和 cmake,主要區別是第一種有 “include c++ support”,比較方便,第二種沒有 “include c++ support”:

第一種:

一共需要創建兩個 android project

首先,要確認 SDK里面有安裝了 CMake 和 NDK,如下

49fc873a70c9db967e020f61bf350a35.png

(1)創建第一個 project,記得勾選 c++ support

66fe7a3a57e57666a2de2764ca65b39d.png

然后一路到finish,第一個 project 就建好了

(2)打開 MainActivity,長這樣的,並且可以看到旁邊有個 cpp 文件

b91edec3950c9058e9208d1a9c0ea457.png

打開 cpp 文件 ,看一下 具體內容

9a1a5529d6525372462064832f4b62d2.png

可以看到這里的類名是 包名+類名+方法名,

(3)為了方便,我們建一個類,名為 NativeUtils,將 MainActivity 中的 native 方法移動到到這個類里面,結果如下:

35955014bdc6c9e65aca2bce9775d3b8.png

015a264a437ac3fca2096883f090669e.png

然后,點擊 Build –> Make Project 或者 ctrl + F9 , 然后切換到 project 目錄,可以看到已經生成 so 庫,

如下:

61fdab5b0469ea43200953203ba57dcd.png

這就是要給其他工程用的,可以看到這樣就生成了,默認是全部類型的 so 都有,如果要部分的話可以在

app 的 build.gradle 中添加過濾,即 abiFilters 指定生成什么格式的 so 文件,moduleName 指定 so 文件 名字,這里沒有進行指定,

(4)將這些 so 文件拷貝出來,建立第二個工程,第二個工程隨意,然后將這些 so 文件拷貝到 libs 目錄下,並在 app 的 build.gradle 中添加依賴

7f30403d7aa065740c682ee4ac36dfee.png

(5)建立一個新的包,和第一個工程 NativeUtils 所在的包名一樣,並且將第一個工程的 NativeUtils 類拷貝過來到這個新建的包下:

e7cec60fc1529ebcb18480e3d286826c.png

(6)這個時候我們在 MainActivity 調用 NativeUtils 中的 方法,毫無疑問,報了錯誤,如下

bbfdad2a498b55ffe367592120dda4fb.png

原因是:開始第一步的時候,我們將 第一個工程 MainActivity 中生成 的 native 方法移動 到 NativeUtils中,cpp 文件的類名稱並沒有修改,打開第一個工程,開始是這樣的

5817fca6298b71fc55ed52a5a7f7424d.png

我們需要改成這樣,因為 這里的類名是 “ 包名+類名+方法名” ,我們改成了 NativieUtils,所以要改成如下:

f500b43b38feecb68fec43fc588cdfaf.png

重新 MakeProject,將 so 文件 復制到第二個工程,再次編譯運行,即可成功運行,打個 Log即可驗證

49f7e2d8574637b0894a9daa6b7f531e.png

兩個小點:

1、關於 so 的 加載,也就是 System.loadLibrary(“native-lib”); 可以看到 目錄里面 這個 so 文件的名稱是

“libnative-lib.so”,這里加載 沒有 “lib” 和 “. so”

2、這 7 種 so 文件常用的 abi 只有三種

第二種:

上面是建立項目的時候勾選了 “include c++ support”,如果沒有勾選呢,也可以自己來,首先創建一個 普通類 JniTest.java

8dd94689547a37641687ceb49eca4dc1.jpe

然后 ALT + F12 呼出控制台 , cd到 main 文件夾,我的包名是 com.example.z.sotest,最后命令如下:

88b42b885b914269298e56b82c6ec182.jpe

接着可以看到生成了 jni 的文件夾和對應的 h 文件,

47d6466bef1ad5706b337460a12ddcaa.jpe

接着,右鍵新建一個 c++ source file,名字叫 native-lib.cpp,然后內容如下:

09f71ba6420b81dafb134307d7b2497d.jpe

這樣導入一個 h 文件有可能后面編譯會出現一個錯誤,如下:

29bcffbdbbf26c1567c32cf81a23745d.jpe

根據提示,很簡單的,將導入的尖括號改成雙引號,即第一句改成

#include "com_example_z_sotest_JniTest.h" 后續的編譯即可成功,

在進行編譯之前,還需要配置一下 gradle,具體如下:

a140604022b226d1e3de9c722812bf65.jpe

可以看到,還需要一個 CMakeLists.txt,我們需要在 app 下新建立一個 CMakeLists.txt,如下:

2045c97ed25ff67b2ca7f4de45b8709b.jpe

順便將 txt 內容貼出來:

# For more information about using CMake with Android Studio, read the

# documentation: https://d.android.com/studio/projects/add-native-code.html

# Sets the minimum version of CMake required to build the native library.

cmake_minimum_required(VERSION 3.4.1)

# Creates and names a library, sets it as either STATIC

# or SHARED, and provides the relative paths to its source code.

# You can define multiple libraries, and CMake builds them for you.

# Gradle automatically packages shared libraries with your APK.

add_library( # Sets the name of the library.

native-lib

# Sets the library as a shared library.

SHARED

# Provides a relative path to your source file(s).

src/main/jni/native-lib.cpp )

# Searches for a specified prebuilt library and stores the path as a

# variable. Because CMake includes system libraries in the search path by

# default, you only need to specify the name of the public NDK library

# you want to add. CMake verifies that the library exists before

# completing its build.

find_library( # Sets the name of the path variable.

log-lib

# Specifies the name of the NDK library that

# you want CMake to locate.

log )

# Specifies libraries CMake should link to your target library. You

# can link multiple libraries, such as libraries you define in this

# build script, prebuilt third-party libraries, or system libraries.

target_link_libraries( # Specifies the target library.

native-lib

# Links the target library to the log library

# included in the NDK.

${log-lib} )

然后 make project,或者 ctrl + F9,即可看到生成了 so 庫,最后通過 textview 簡單輸出一段文字驗證下:

fa559732a5fd03de92fc3c1404e82dc5.png

5c28c8539c349480d6ee3d05981d8606.jpe

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

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值