我的NDK學習開發筆記(一)

NDK使用Log,jstring到char*

#include "com_xcc_ndkstudy_GetString.h"
#include <string.h>
#include <android/log.h>

#define  LOG_TAG    "--xcc-native-dev--"
//定義log使用
#define  LOGI(...)  __android_log_print(ANDROID_LOG_INFO, LOG_TAG, __VA_ARGS__)

jstring Java_com_xcc_ndkstudy_GetString_stringToJni(JNIEnv *jniEnv, jobject jobj) {
    LOGI("test");
    jstring jStr = jniEnv->NewStringUTF("磁磁帥");
    jboolean isCopy;
    //將jstring轉到char*
    const char *str = jniEnv->GetStringUTFChars(jStr, &isCopy);
    if (0 != str) {
        LOGI("test%s", str);
    }
//回收str
    jniEnv->ReleaseStringUTFChars(jStr, str);
    //delete str;
    LOGI("test%s", str);
    str = 0;
    return jStr;
}
ReleaseStringUTFChars與delete 功能相同,使用後效果一樣,應該可以隨意使用。
//log使用時需要添加ldLibs "log"//實現__android_log_print
位置如下:
ndk {
moduleName"xccJnis"
ldLibs"log"//實現__android_log_print
abiFilters'armeabi','x86','armeabi-v7a','arm64-v8a','x86_64'
//輸出指定三種abi體系結構下的so庫。
}

添加其他C++標準庫支持

#include <string>//提示找不到string時,需要添加C++其他標準庫
添加以下兩行即可
stl ="stlport_shared"//添加其他C++標準庫支持
cFlags("-std=c++11")
完整配置如下

ndk {
moduleName"xccJnis"
ldLibs"log"//實現__android_log_print
stl ="stlport_shared"//添加其他C++標準庫支持
cFlags("-std=c++11")
abiFilters'armeabi','x86','armeabi-v7a','arm64-v8a','x86_64'
//輸出指定三種abi體系結構下的so庫。
}
如果是eclipse,需要將Application.mk放在jni目錄下(內容如下)
APP_STL := stlport_static

C/C++申請內存

#include "com_xcc_app2_XccLibs.h"
#include <string.h>
#include <android/log.h>
#include <stdlib.h>

#define  LOG_TAG    "--xcc-native-dev--"
#define  LOGI(...)  __android_log_print(ANDROID_LOG_INFO, LOG_TAG, __VA_ARGS__)

void Java_com_xcc_app2_XccLibs_cRun(JNIEnv * env, jobject jObj){
LOGI("--磁磁帥-->");
int *intArrays = (int *) malloc(sizeof(int) * 16);
if(NULL==intArrays){
LOGI("--申請內存失敗-->");
}else{
LOGI("--申請內存成功-->");
*intArrays = 4;
intArrays++;
*intArrays = 2;
LOGI("--打印值-->%d", *intArrays);
intArrays--;
LOGI("--打印值-->%d", *intArrays);
LOGI("--15打印值-->%d", intArrays[15]);
LOGI("--改變申請到的內存大小-->");
intArrays = (int *) realloc(intArrays, sizeof(int) * 32);
free(intArrays);//釋放內存
intArrays = NULL;
}
//C++ 申請內存
int *ints = new int[16];
if(NULL==ints){
LOGI("--C++申請內存失敗-->");
}else{
LOGI("--C++申請內存成功-->");
ints++;
*ints=10;
LOGI("--打印值-->%d", *ints);
ints--;
/**
 * 注:ints[1]相當於 ints+=1; *ints; ints-=1;
 */
LOGI("--打印值-->%d", ints[1]);
delete ints;
}
}

注:int*ints = new int[16];更改成int*ints = new int[160*1024*1024];。然後多次調用測試發現new 比 malloc 更加穩定,malloc會出現申請失敗,可能是之前釋放失敗等多種原因導致,但是new都是可以成功申請到內存。SO,不建議使用malloc。
注:將delete註釋掉,然後多次調用導致程序閃退。說明new在申請內存時,申請不到內存會崩潰。而malloc申請不到內存是不會崩潰。SO,new出來的對象一定得記得delete。

學習時編寫的完整代碼,下載地址:
碼雲:http://git.oschina.net/rookieci/NDKStudy
github:https://github.com/cookieci/NDKStudy













































發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章