本文已授權微信公眾號:鴻洋(hongyangAndroid)在微信公眾號平臺原創(chuàng)首發(fā)。
本文為走進AndroidStudio下的NDK(一)的續(xù)篇遭赂,主要介紹so包的編譯以及如何進行使用十减,也就是平常我們集成三方SDK時導入的那些so包栈幸,最終達到我們能夠提供給別人使用so包的程度,從而確保核心c代碼的隱私性帮辟。接下來速址,我們就一步一步探索如何生成一個so包提供給別人使用。
項目創(chuàng)建
接著第一篇文章的項目由驹,我們已經(jīng)可以能夠進行java到C的調(diào)用芍锚,算是已經(jīng)初步打通了之間的橋梁,具體相互調(diào)用和高級的進行c開發(fā)蔓榄,后續(xù)文章會陸續(xù)講到并炮,現(xiàn)在主要還是以helloword的項目進行演示。項目目錄是這樣的:
其中gradle中配置了一個ndk moduleName甥郑,指定為hello
從目錄中可以看到逃魄,還自動生成了mk文件,由于在gradle中對ndk就只配置了moduleName澜搅,其他都是用的默認配置伍俘,因此生成的也是默認mk文件配置,可以看得出mk文件和以前我們在Eclipse中開發(fā)NKD差不多一樣的勉躺。
so包出現(xiàn)
在上面項目的基礎上AndroidStudio生成so包是相當方便的癌瘾,按照上面的配置Rebuild Project,然后找到目錄 \app\build\intermediates\ndk\debug\lib
下饵溅,這個時候會生成各類ABI版本下的so包妨退,這些so包都是以libhello為名稱的,上篇有提到這個名稱的格式是固定的,由lib+moduleName組成咬荷,在代碼中l(wèi)oadlibrary時填寫moduleName冠句。
so使用
AndroidStudio中so包存放的目錄默認是在main/jniLibs下面,如果沒有這個目錄可以創(chuàng)建并復制所有平臺的so包到該目錄下幸乒,一般情況我們比較傾向于把這些so包和jar包都放在app/libs下面轩端,同樣將so全部拷貝到libs下面,也是可以逝变,不過需要在gradle中進行一項目錄配置基茵,如下
添加這個配置,就是將main下面的確實jnilibs目錄指定為libs壳影,在系統(tǒng)加載so的時候會去libs目錄下加載拱层。
然后,這個時候你可以刪掉jni目錄下的c文件宴咧,刪掉gradle中的moduleName配置根灯,就如平常集成三方SDK時一樣,拷貝so包到libs下面掺栅,跑起來就可以了烙肺,不過這個時候java類中的native方法可能會報紅,因為移除c文件氧卧,沒有鏈接到桃笙,但是不影響的,忽略之即可沙绝。
PPPPPS
到上面那一步其實就已經(jīng)完成so包的創(chuàng)建和使用了窄锅,在使用過程中我們基本都是使用的默認配置箱亿,當然我們可以進行在gradle中配置以致自己項目所需。在項目創(chuàng)建的基礎上:
- 添加需要支持的lib包:
ldLibs("log")
- 指定編譯出所需的平臺:
abiFilters("armeabi", "armeabi-v7a", "x86")
牵触,這里指定這三個 - STL支持:
stl = "system"
丙曙, STL目前可支持system(系統(tǒng)默認的最小支持的C++運行時庫)赖晶;stlport_static(以靜態(tài)鏈接的方式使用stlport版本的STL)巾兆;stlport_shared(以動態(tài)鏈接的方式使用stlport版本的STL)如捅;gnustl_static(以靜態(tài)鏈接的方式使用gnu版本的STL)
- cFlags標記:
cFlags("-std=c++11")
Rebuild Project之后,對應會生成我們知道的so包
小小總結一下
使用AndroidStudio進行JNI開發(fā)相對來說比以前在Eclipse中開發(fā)更加簡便了样傍,也不需要Android.mk横缔,Application.mk等文件,這些完全可以在gradle中進行配置铭乾,具體需要配置那些信息可以參考gradle中的NdkOptions類剪廉,這個類就是上面配置ndk節(jié)點的對應java類娃循。我們只需要關系寫c文件以及和java直接的相互調(diào)用即可炕檩,省去了很多的麻煩,接下來,就可以玩轉JNI開發(fā)了笛质,前提是你要擅長C哦~~~騷年泉沾,玩起來吧!妇押!!