android 控制 JNI 日志输出

简介

在android 应用开发过程中,有时候会遇到需要使用JNI 技术调用C或者C++已经实现功能或者引入C 或者 C++ 编写好的库。因此需要使用到JNI技术。
在使用过程有,会有这样的一个需求,需求描述如下:

  1. 在调试过程中,在C 或者C++ 源码中,需要输出调试日志。
  2. 在发布的版本中,C 或者 C++ 的调试日志,需要关闭。

在android 打包过程中可以选择release 或者 debug,一般打包为 release包,java 代码通过Build.config可以对输出日志等调试信息进行控制,因此猜想,在build.gradle中添加一些控制,也能同时控制JNI代码是否输出调试日志。本文就是完成这样的一个小功能。

在添加编译参数

在build.gradle中根据release或者debug添加编译参数,即gcc或者g++里面提到的编译宏

defaultConfig{
	buildTypes {
		release {
			externalNativeBuild {
                cmake {
                    cppFlags " "
                    cFlags " "
                }
            }
		}
         debug{
         // 添加编译宏,在C 或者 C++源码中添加 LOG_DEBUG 的编译宏
         externalNativeBuild {
                cmake {
                    cppFlags "-DLOG_DEBUG"
                    cFlags "-DLOG_DEBUG"
                }
            }
         }   
	}
}

JNI 日志输出

JNI 日志输出的源码可这样实现,如果存在宏,则调用android/log.h的方法输出日志,否则不输出日志。

#include  <android/log.h>

    #ifdef LOG_DEBUG
        #define LOGI(TAG,...) __android_log_print(ANDROID_LOG_INFO,TAG,__VA_ARGS__)
        // 定义debug信息
        #define LOGD(TAG,...) __android_log_print(ANDROID_LOG_DEBUG,TAG, __VA_ARGS__)
        // 定义error信息
        #define LOGE(TAG,...) __android_log_print(ANDROID_LOG_ERROR,TAG,__VA_ARGS__)
    #else
        #define LOGI(TAG,...)
        // 定义debug信息
        #define LOGD(TAG,...)
        // 定义error信息
        #define LOGE(TAG,...)
    #endif

使用

#define TAG "TEST_TAG"
void funcTest1(){
	LOGI(TAG,"输出日志");
}
  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值