Android Studio 使用JNI筆記

主要記錄一些as使用JNI的一些配置,避免忘記每次都要到處查找。。嚎幸。
使用as開發(fā)可以不用創(chuàng)建Android.mk文件疙挺,Application.mk文件,只要在build.gradle文件中配置相應(yīng)的參數(shù)即可使用。。

1.JNI文件的創(chuàng)建

首先創(chuàng)建Java的native類


public classMyJniTest {

public native voidprint(String str);

public native String getName();

}

然后運行項目,運行完成后在項目的build/intermediates/classes/debug/目錄下面可以看到生成的MyJniTest.class文件,然后用java命令生成對應(yīng)的JNI的.h文件,命令如下:


bogon:asjnitest yjg$ cd build/intermediates/classes/debug/
bogon:debug yjg$ ls
android com
bogon:debug yjg$ javah -jni com.jni.yjg.asjnitest.MyJniTest

創(chuàng)建完成后就可以看到對應(yīng)的.h文件栗竖,在../debug/下面

B712C089-290A-4CFA-AD97-391F9A3F695C.png

具體代碼如下:

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

#ifndef _Included_com_jni_yjg_asjnitest_MyJniTest
#define _Included_com_jni_yjg_asjnitest_MyJniTest
#ifdef __cplusplus
extern "C" {
#endif
/*
 * Class:     com_jni_yjg_asjnitest_MyJniTest
 * Method:    print
 * Signature: (Ljava/lang/String;)V
 */
JNIEXPORT void JNICALL Java_com_jni_yjg_asjnitest_MyJniTest_print
  (JNIEnv *, jobject, jstring);

/*
 * Class:     getName
 * Signature: ()Ljava/lang/String;
 */
JNIEXPORT jstring JNICALL Java_com_jni_yjg_asjnitest_MyJniTest_getName
  (JNIEnv *, jobject);

#ifdef __cplusplus
}
#endif
#endif

2.JNI配置

在項目的build.gradle文件中配置jni的參數(shù)了

debug{   
       ndk{        
            moduleName "MyJniTest"http://生成的so名字        
            stl "stlport_static"        
            ldLibs "log"   //實現(xiàn)__android_log_print    
            abiFilters "armeabi", "armeabi-v7a", "x86"  //輸出指定三種  abi體系結(jié)構(gòu)下的so庫。    
      }
}

其中stl就相當(dāng)于Android.mk文件中的APP_STL屬性渠啤。大概就是導(dǎo)入C++運行時庫吧狐肢。。
abiFilters就相當(dāng).mk文件中的APP_ABI沥曹。用于生成不同架構(gòu)的.so包份名。

3.實現(xiàn)jni方法
拷貝.h文件到項目的jni目錄下面。(as的jni目錄默認(rèn)在main下面妓美,需要自己創(chuàng)建僵腺,當(dāng)然也可以在build.gradle中自己指定)
創(chuàng)建對應(yīng)的.cpp文件
然后就是實現(xiàn).h文件中的方法,.cpp文件的具體代碼

#include <jni.h>
#include <com_jni_yjg_asjnitest_MyJniTest.h>
#include <android/log.h>


JNIEXPORT void JNICALL Java_com_jni_yjg_asjnitest_MyJniTest_print
(JNIEnv * env, jobject obj, jstring jsstr){   
 __android_log_print(ANDROID_LOG_DEBUG,"android","hello  jni");
}

 JNIEXPORT jstring JNICALL Java_com_jni_yjg_asjnitest_MyJniTest_getName
        (JNIEnv * env, jobject jobject1){
    return env->NewStringUTF("I'm jni");

}

ok以上就是JNI部分的實現(xiàn)了。
然后就是java層調(diào)用jni了,先是加載jni庫:

static {   
 System.loadLibrary("MyJniTest");
}

接著就是調(diào)用jni的方法了:

MyJniTest test=new MyJniTest();
test.print("aaa");
System.out.println("name:"+test.getName());

OK 運行項目壶栋。辰如。

這個就是Logcal中打印出來日志:

07-17 16:52:47.208 2211-2211/com.jni.yjg.asjnitest D/android: hello  jni
07-17 16:52:47.208 2211-2211/com.jni.yjg.asjnitest I/System.out: name:I'm jni

OK,這就說明java層通過JNI和C++交互成功了贵试。
補充說明:
__android_log_print(ANDROID_LOG_DEBUG,"android","hello jni")這個是jni的log也能在Logcat中顯示琉兜,可以用來調(diào)試C++代碼,使用方法也和android的log類似毙玻,比如:ANDROID_LOG_DEBUG對應(yīng)就是Log.d
可以簡單的封裝下:

#ifndef MY_APPLICATION_EBEN_HPC_LOG_H
#define MY_APPLICATION_EBEN_HPC_LOG_H
#ifdef __cplusplus
extern "C" {
#endif
#include <android/log.h>
// 宏定義類似java 層的定義,不同級別的Log LOGI, LOGD, LOGW, LOGE, LOGF豌蟋。 對就Java中的 Log.i log.d
#define LOG_TAG    "JNILOG" // 這個是自定義的LOG的標(biāo)識
//#undef LOG // 取消默認(rèn)的LOG
#define LOGI(...)  __android_log_print(ANDROID_LOG_INFO,LOG_TAG, __VA_ARGS__)
#define LOGD(...)  __android_log_print(ANDROID_LOG_DEBUG,LOG_TAG, __VA_ARGS__)
#define LOGW(...)  __android_log_print(ANDROID_LOG_WARN,LOG_TAG, __VA_ARGS__)
#define LOGE(...)  __android_log_print(ANDROID_LOG_ERROR,LOG_TAG, __VA_ARGS__)
#define LOGF(...)  __android_log_print(ANDROID_LOG_FATAL,LOG_TAG, __VA_ARGS__)

#ifdef __cplusplus
}
#endif

這樣子使用的時候直接調(diào)用:

LOGD("log.d 這是Jni中的log: xxxxxxx");

這就和android中的log方法差不多了。桑滩。

??打完收工~~~~

最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請聯(lián)系作者
  • 序言:七十年代末梧疲,一起剝皮案震驚了整個濱河市,隨后出現(xiàn)的幾起案子运准,更是在濱河造成了極大的恐慌往声,老刑警劉巖,帶你破解...
    沈念sama閱讀 222,627評論 6 517
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件戳吝,死亡現(xiàn)場離奇詭異,居然都是意外死亡贯涎,警方通過查閱死者的電腦和手機听哭,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 95,180評論 3 399
  • 文/潘曉璐 我一進(jìn)店門,熙熙樓的掌柜王于貴愁眉苦臉地迎上來,“玉大人陆盘,你說我怎么就攤上這事普筹。” “怎么了隘马?”我有些...
    開封第一講書人閱讀 169,346評論 0 362
  • 文/不壞的土叔 我叫張陵太防,是天一觀的道長。 經(jīng)常有香客問我酸员,道長蜒车,這世上最難降的妖魔是什么? 我笑而不...
    開封第一講書人閱讀 60,097評論 1 300
  • 正文 為了忘掉前任幔嗦,我火速辦了婚禮酿愧,結(jié)果婚禮上,老公的妹妹穿的比我還像新娘邀泉。我一直安慰自己嬉挡,他們只是感情好,可當(dāng)我...
    茶點故事閱讀 69,100評論 6 398
  • 文/花漫 我一把揭開白布汇恤。 她就那樣靜靜地躺著庞钢,像睡著了一般。 火紅的嫁衣襯著肌膚如雪因谎。 梳的紋絲不亂的頭發(fā)上基括,一...
    開封第一講書人閱讀 52,696評論 1 312
  • 那天,我揣著相機與錄音蓝角,去河邊找鬼阱穗。 笑死,一個胖子當(dāng)著我的面吹牛使鹅,可吹牛的內(nèi)容都是我干的揪阶。 我是一名探鬼主播,決...
    沈念sama閱讀 41,165評論 3 422
  • 文/蒼蘭香墨 我猛地睜開眼患朱,長吁一口氣:“原來是場噩夢啊……” “哼鲁僚!你這毒婦竟也來了?” 一聲冷哼從身側(cè)響起裁厅,我...
    開封第一講書人閱讀 40,108評論 0 277
  • 序言:老撾萬榮一對情侶失蹤冰沙,失蹤者是張志新(化名)和其女友劉穎,沒想到半個月后执虹,有當(dāng)?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體拓挥,經(jīng)...
    沈念sama閱讀 46,646評論 1 319
  • 正文 獨居荒郊野嶺守林人離奇死亡,尸身上長有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點故事閱讀 38,709評論 3 342
  • 正文 我和宋清朗相戀三年袋励,在試婚紗的時候發(fā)現(xiàn)自己被綠了侥啤。 大學(xué)時的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片当叭。...
    茶點故事閱讀 40,861評論 1 353
  • 序言:一個原本活蹦亂跳的男人離奇死亡,死狀恐怖盖灸,靈堂內(nèi)的尸體忽然破棺而出蚁鳖,到底是詐尸還是另有隱情,我是刑警寧澤赁炎,帶...
    沈念sama閱讀 36,527評論 5 351
  • 正文 年R本政府宣布醉箕,位于F島的核電站,受9級特大地震影響徙垫,放射性物質(zhì)發(fā)生泄漏讥裤。R本人自食惡果不足惜,卻給世界環(huán)境...
    茶點故事閱讀 42,196評論 3 336
  • 文/蒙蒙 一松邪、第九天 我趴在偏房一處隱蔽的房頂上張望坞琴。 院中可真熱鬧,春花似錦逗抑、人聲如沸剧辐。這莊子的主人今日做“春日...
    開封第一講書人閱讀 32,698評論 0 25
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽荧关。三九已至,卻和暖如春褂傀,著一層夾襖步出監(jiān)牢的瞬間忍啤,已是汗流浹背。 一陣腳步聲響...
    開封第一講書人閱讀 33,804評論 1 274
  • 我被黑心中介騙來泰國打工仙辟, 沒想到剛下飛機就差點兒被人妖公主榨干…… 1. 我叫王不留同波,地道東北人。 一個月前我還...
    沈念sama閱讀 49,287評論 3 379
  • 正文 我出身青樓叠国,卻偏偏與公主長得像未檩,于是被迫代替她去往敵國和親。 傳聞我的和親對象是個殘疾皇子粟焊,可洞房花燭夜當(dāng)晚...
    茶點故事閱讀 45,860評論 2 361

推薦閱讀更多精彩內(nèi)容