Android JNI中增加LOGCAT,LOG
发布日期:2021-07-01 05:54:19
浏览次数:2
分类:技术文章
本文共 2236 字,大约阅读时间需要 7 分钟。
最近在研究Android 2.3.3源代码的C/C++层,需要对代码进行一些调试,但是奇怪的是,直接添加LOGD("XXXXXXXX");,使用logcat却看不到任何输出,换成LOGI、LOGV、LOGW、LOGE也没有效果。于是在网上查找解决方法,经过几次试验,终于找到了,现在贴到下面备忘: 第一步:在对应的mk文件中加入:LOCAL_LDLIBS := -llog 第二步:在要使用LOG的cpp文件中加入:#include第三步:这样就可以使用了:LOGD("我要看到的调试信息^_^"); 这样,在logcat端看到的输出是: D/keymatch( 32):我要看到的调试信息^_^ 如果想改变输出中的各项内容,可以参考相应颜色的标示,比如,如果想定义LOGE,就可以把上面的ANDROID_LOG_DEBUG改成ANDROID_LOG_ERROR,同理,LOGI神马的也都以此类推:#define LOGD(...) __android_log_print(ANDROID_LOG_DEBUG, "keymatch", __VA_ARGS__)
#define LOGV(...) __android_log_print(ANDROID_LOG_VERBOSE, "ProjectName", __VA_ARGS__) #define LOGD(...) __android_log_print(ANDROID_LOG_DEBUG , "ProjectName", __VA_ARGS__)#define LOGI(...) __android_log_print(ANDROID_LOG_INFO , "ProjectName", __VA_ARGS__)#define LOGW(...) __android_log_print(ANDROID_LOG_WARN , "ProjectName", __VA_ARGS__)#define LOGE(...) __android_log_print(ANDROID_LOG_ERROR , "ProjectName", __VA_ARGS__)当然,如果不嫌麻烦,也可以直接使用__android_log_print函数,而不define定义LOGxxx 如果还想了解更详细的内容,也可以参考这篇文章: 《在android 输出log 信息 用于调试》 另外,有文章称此方法在编译动态库的时候可能会出问题,会提示cannot find -llog的错误。意思是找不到liblog.so这个库文件。 因此需要改成 LOCAL_LDLIBS:= -L$(SYSROOT)/usr/lib -llog 才可以正常编译。但是我这边编译动态库的时候,好像不用这样改也行,没发现编译时提示“cannot find -llog”的错误 Android NDK发布后,java+C的编程方式成为android上性能编程的首选。 但在C中调试困难,因此能使用logcat成为必须的要求。 关于在Native代码中使用logcat,网上有很多说法,大部分有所欠缺,有的根本是错的。 要使用logcat,首先在代码中要引入 log的头文件。
#include然后你可以简单的通过
__android_log_write(ANDROID_LOG_ERROR,"Tag","Message");
方法向logcat输出。
log 级别有很多 : ANDROID_LOG_UNKNOWN, ANDROID_LOG_DEFAULT, ANDROID_LOG_VERBOSE, ANDROID_LOG_DEBUG, ANDROID_LOG_INFO, ANDROID_LOG_WARN, ANDROID_LOG_ERROR, ANDROID_LOG_FATAL, ANDROID_LOG_SILENT, 这样写完以后,如果直接编译,就会报 __android_log_write 方法undefined. 怎么回事呢?关键是在设置编译选项上面。 在Android.mk文件里,可以指定一个LOCAL_LDLIBS的参数。如果不指定,那么编译的时候,只会引入默认的几个重要的lib,比如libc之类的。 如果要用log,那就要把 liblog给引进来。 网上很多的写法是 LOCAL_LDLIBS := -llog ,这在build static lib的时候没什么问题。如果是build shared lib,就会报个 cannot find -llog的错误。意思是找不到liblog.so这个库文件。 因此需要改成 LOCAL_LDLIBS := -L$(SYSROOT)/usr/lib -llog 才可以正常编译。 其中-L参数是指定了搜索lib的路径。 下面是一个android.mk的内容的例子:LOCAL_PATH := $(call my-dir)include $(CLEAR_VARS)LOCAL_MODULE := TestNdkNetworkLOCAL_SRC_FILES := HttpConnection.cppLOCAL_LDLIBS := -L$(SYSROOT)/usr/lib -lloginclude $(BUILD_SHARED_LIBRARY)
转载地址:https://panda1234lee.blog.csdn.net/article/details/8253770 如侵犯您的版权,请留言回复原文章的地址,我们会给您删除此文章,给您带来不便请您谅解!
发表评论
最新留言
做的很好,不错不错
[***.243.131.199]2024年04月19日 13时00分42秒
关于作者
喝酒易醉,品茶养心,人生如梦,品茶悟道,何以解忧?唯有杜康!
-- 愿君每日到此一游!
推荐文章
软件测试用例的基本要素
2019-05-08
如何实现 itoa
2019-05-08
Python log 日志的使用
2019-05-08
关于sprintf的一些东西(在stdio.h里)
2019-05-08
八皇后的思考(DFS)
2019-05-08
zoj 1004 dfs+栈
2019-05-08
"《算法导论》之‘线性表’":基于静态分配的数组的顺序表
2019-05-08
ModelSim 仿真教程
2019-05-08
Numpy:dot()函数
2019-05-08
机器学习:SVM(基础理解)
2019-05-08
Python:itertools库的使用
2019-05-08
Python:内置函数zip()
2019-05-08
高数:其它
2019-05-08
机器学习:SVM(scikit-learn 中的 SVM:LinearSVC)
2019-05-08
机器学习:SVM(非线性数据分类:SVM中使用多项式特征和核函数SVC)
2019-05-08
机器学习:SVM(核函数、高斯核函数RBF)
2019-05-08
机器学习:SVM(scikit-learn 中的 RBF、RBF 中的超参数 γ)
2019-05-08
机器学习:SVM(SVM 思想解决回归问题)
2019-05-08
Hbase学习笔记(一)
2019-05-08