NDK JNI 日志打印与写入文件

1、全局获取JNIEnv对象

Env_util.h

class JniData{
public:
    static JavaVM *vm;
};


JNIEnv *GetAttachEnv(int *attach);

jint DetachEnv();

Env_util.cpp

#include <jni.h>
#include "Env_util.h"

JavaVM *JniData::vm = nullptr;

/**
* 依据JavaVM获取JNIEnv对象
* @param vm
* @param attach
* @return
*/
JNIEnv *GetAttachEnv(int *attach) {
    if (JniData::vm == NULL){
        return NULL;
    }
    *attach = 0;
    JNIEnv *jni_env = NULL;
    int status = JniData::vm->GetEnv((void **) &jni_env, JNI_VERSION_1_6);
    if (status == JNI_EDETACHED || jni_env == NULL) {
        status = JniData::vm->AttachCurrentThread(&jni_env, NULL);
        if (status < 0) {
            jni_env = NULL;
        } else {
            *attach = 1;
        }
    }
    return jni_env;
}


jint DetachEnv() {
    return JniData::vm->DetachCurrentThread();
}

2、log日志打印

android_log.h

#include<android/log.h>
#include <jni.h>
#include <chrono>
//开关
void setEnableLog(bool enable);
bool getEnableLog();

void LOGD(const char *msg, ...);
void LOGI(const char *msg, ...);
void LOGW(const char *msg, ...);
void LOGE(const char *msg, ...);
void LOGF(const char *msg, ...);

//#define ANDROID_JNI_LOG 1 //打开/屏蔽此宏定义,用于切换打开Jni日志开关
//
//#ifdef ANDROID_JNI_LOG
//
//#define TAG "ndk-jni" // 这个是自定义的LOG的标识
//
//#define LOGD(...) __android_log_print(ANDROID_LOG_DEBUG,TAG ,__VA_ARGS__) // 定义LOGD类型
//#define LOGI(...) __android_log_print(ANDROID_LOG_INFO,TAG ,__VA_ARGS__) // 定义LOGI类型
//#define LOGW(...) __android_log_print(ANDROID_LOG_WARN,TAG ,__VA_ARGS__) // 定义LOGW类型
//#define LOGE(...) __android_log_print(ANDROID_LOG_ERROR,TAG ,__VA_ARGS__) // 定义LOGE类型
//#define LOGF(...) __android_log_print(ANDROID_LOG_FATAL,TAG ,__VA_ARGS__) // 定义LOGF类型
//
//#else
//
//#define LOGD(...)
//#define LOGI(...)
//#define LOGW(...)
//#define LOGE(...)
//#define LOGF(...)
//
//#endif

android_log.cpp

#include <cstdio>
#include <cstdlib>
#include <time.h>
#include "android_log.h"

#define TAG "ndk-jni" // 这个是自定义的LOG的标识

static bool isEnableLog = false;
static char *file_path = nullptr;

void setEnableLog(bool enable) {
    isEnableLog = enable;
}
void setFilePath( char *file){
  file_path = file;
}
bool getEnableLog(){
    return isEnableLog;
}

long long GetTimeStamp() {
    long long timestamp = std::chrono::duration_cast<std::chrono::microseconds>(
            std::chrono::system_clock::now().time_since_epoch()).count();
    return timestamp;
}

void writeToFile(const char *msg, va_list vaList) {
    if (!file_path) {
        return;
    }

    char *contentMsg;
    int len = vasprintf(&contentMsg, msg, vaList);

    if (len > 0) {
        FILE *fp = fopen(file_path, "a+");
        if (!fp) {
            __android_log_print(ANDROID_LOG_DEBUG,TAG ,"The file %s open failed",file_path);
            return;
        }
        long long timeStamp = GetTimeStamp();
        time_t dt = timeStamp / 1000000;
        int ms = (int) (timeStamp - dt * 1000000);
        tm t; // tm结构指针
        localtime_r(&dt, &t);

        fprintf(fp, "%04d-%02d-%02d %02d:%02d:%02d.%04d",
                t.tm_year + 1900, t.tm_mon + 1, t.tm_mday, t.tm_hour, t.tm_min, t.tm_sec, ms);

        fprintf(fp, "[%s]:%s", TAG, contentMsg);
        fprintf(fp, "\n");
//        fflush(fp); //刷新缓存会导致书写很慢
        fclose(fp);

        free(contentMsg);
    }
}

void LOGD(const char *msg, ...) {

    if (!isEnableLog){
        return;
    }

     if (msg == nullptr){
        return;
    }
    va_list vaList;
    va_start(vaList, msg);
    __android_log_vprint(ANDROID_LOG_DEBUG, TAG, msg, vaList);
    writeToFile(msg, vaList);
    va_end(vaList);
}

void LOGI(const char *msg, ...) {
    if (!isEnableLog){
        return;
    }

     if (msg == nullptr){
        return;
    }
    va_list vaList;
    va_start(vaList, msg);
    __android_log_vprint(ANDROID_LOG_INFO,TAG,msg,vaList);
    writeToFile(msg, vaList);
    va_end(vaList);
}

void LOGW(const char *msg, ...) {
    if (!isEnableLog){
        return;
    }
    if (msg == nullptr){
        return;
    }
    va_list vaList;
    va_start(vaList, msg);
    __android_log_vprint(ANDROID_LOG_WARN,TAG,msg,vaList);
    writeToFile(msg, vaList);
    va_end(vaList);
}

void LOGE(const char *msg, ...) {
    if (!isEnableLog){
        return;
    }
   if (msg == nullptr){
        return;
    }
    va_list vaList;
    va_start(vaList, msg);
    __android_log_vprint(ANDROID_LOG_ERROR,TAG,msg,vaList);
    writeToFile(msg, vaList);
    va_end(vaList);
}


void LOGF(const char *msg, ...){
    if (!isEnableLog){
        return;
    }

    if (msg == nullptr){
        return;
    }
    va_list vaList;
    va_start(vaList, msg);
    __android_log_vprint(ANDROID_LOG_DEFAULT,TAG,msg,vaList);
     writeToFile(msg, vaList);
    va_end(vaList);
}

最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 159,835评论 4 364
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 67,598评论 1 295
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 109,569评论 0 244
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 44,159评论 0 213
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 52,533评论 3 287
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 40,710评论 1 222
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 31,923评论 2 313
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 30,674评论 0 203
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 34,421评论 1 246
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 30,622评论 2 245
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 32,115评论 1 260
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 28,428评论 2 254
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 33,114评论 3 238
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 26,097评论 0 8
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 26,875评论 0 197
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 35,753评论 2 276
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 35,649评论 2 271

推荐阅读更多精彩内容