Android-NDK:JNI本地文件中怎么调试打印输出到LOGCAT

---------------------------------------华丽的分割线----------------------------------------... ---------------------------------------华丽的分割线-----------------------------------------1. 第一步: 如果您是用BUILD_SHARED_LIBRARY生成.so,那么在Android.apk中添加下面语句 LOCAL_LDLIBS:=-L$(SYSROOT)/usr/lib -llog (注:若生成static的.a,只需添加 LOCAL_LDLIBS:=-llog )2. 第二步 在相应的h/c/cpp文件中添加下面语句(确定您已安装了NDK)//---------------------------------------------------// Log//---------------------------------------------------#define JNI_DEBUG#ifdef JNI_DEBUG#ifndef LOG_TAG#define LOG_TAG 展开
 我来答
QQMSD8
2015-08-25 · 知道合伙人软件行家
QQMSD8
知道合伙人软件行家
采纳数:6788 获赞数:13239
没有做不到,只有想不到,帮助别人的同时也是对自己的提升

向TA提问 私信TA
展开全部
加入头文件
#include <android/log.h>
函数__android_log_print(ANDROID_LOG_INFO,LOG_TAG,TITLE)
第一个参数ANDROID_LOG_INFO(还有ANDROID_LOG_ERROR等),表示什么类型
的输出,上面的函数相当于android的java代码的Log.i(LOG_TAG,TITLE),第二个参数就是logcat里的tag,第三个就是打印的内容。具体的请到log.h中自己查看。
Android之NDK开发
一、NDK产生的背景
Android平台从诞生起,就已经支持C、C++开发。众所周知,Android的SDK基于Java实现,这意味着基于Android SDK进行开发的第三方应用都必须使用Java语言。但这并不等同于“第三方应用只能使用Java”。在Android SDK首次发布时,Google就宣称其虚拟机Dalvik支持JNI编程方式,也就是第三方应用完全可以通过JNI调用自己的C动态库,即在Android平台上,“Java+C”的编程方式是一直都可以实现的。
不过,Google也表示,使用原生SDK编程相比Dalvik虚拟机也有一些劣势,Android SDK文档里,找不到任何JNI方面的帮助。即使第三方应用开发者使用JNI完成了自己的C动态链接库(so)开发,但是so如何和应用程序一起打包成apk并发布?这里面也存在技术障碍。比如程序更加复杂,兼容性难以保障,无法访问Framework API,Debug难度更大等。开发者需要自行斟酌使用。
于是NDK就应运而生了。NDK全称是Native Development Kit。
NDK的发布,使“Java+C”的开发方式终于转正,成为官方支持的开发方式。NDK将是Android平台支持C开发的开端。

二、为什么使用NDK
1.代码的保护。由于apk的java层代码很容易被反编译,而C/C++库反汇难度较大。
2.可以方便地使用现存的开源库。大部分现存的开源库都是用C/C++代码编写的。
3.提高程序的执行效率。将要求高性能的应用逻辑使用C开发,从而提高应用程序的执行效率。
4.便于移植。用C/C++写得库可以方便在其他的嵌入式平台上再次使用。

三、NDK简介
1.NDK是一系列工具的集合
NDK提供了一系列的工具,帮助开发者快速开发C(或C++)的动态库,并能自动将so和java应用一起打包成apk。这些工具对开发者的帮助是巨大的。
NDK集成了交叉编译器,并提供了相应的mk文件隔离CPU、平台、ABI等差异,开发人员只需要简单修改mk文件(指出“哪些文件需要编译”、“编译特性要求”等),就可以创建出so。
NDK可以自动地将so和Java应用一起打包,极大地减轻了开发人员的打包工作。
2.NDK提供了一份稳定、功能有限的API头文件声明
Google明确声明该API是稳定的,在后续所有版本中都稳定支持当前发布的API。从该版本的NDK中看出,这些API支持的功能非常有限,包含有:C标准库(libc)、标准数学库(libm)、压缩库(libz)、Log库(liblog)。
百度网友fc870bfa3
推荐于2016-04-20 · TA获得超过764个赞
知道小有建树答主
回答量:443
采纳率:100%
帮助的人:134万
展开全部
1. 第一步:
如果是用BUILD_SHARED_LIBRARY生成.so,那么在Android.apk中添加下面语句
LOCAL_LDLIBS:=-L$(SYSROOT)/usr/lib -llog
(注:若生成static的.a,只需添加 LOCAL_LDLIBS:=-llog )
2. 第二步
在相应的h/c/cpp文件中添加下面语句(确定已安装了NDK)
//--------------------------------------------------- // Log //--------------------------------------------------- #define JNI_DEBUG #ifdef JNI_DEBUG #ifndef LOG_TAG #define LOG_TAG "JNI_DEBUG" #endif #include <android/log.h> #define LOGE(msg) __android_log_print(ANDROID_LOG_ERROR, LOG_TAG, msg) #define LOGI(msg) __android_log_print(ANDROID_LOG_INFO, LOG_TAG, msg) #define LOGD(msg) __android_log_print(ANDROID_LOG_DEBUG, LOG_TAG, msg) #endif
已赞过 已踩过<
你对这个回答的评价是?
评论 收起
jiangxinyue052
2013-03-21 · TA获得超过644个赞
知道小有建树答主
回答量:186
采纳率:50%
帮助的人:99.3万
展开全部
加入头文件
#include <android/log.h>
函数
__android_log_print(ANDROID_LOG_INFO,LOG_TAG,TITLE)
第一个参数ANDROID_LOG_INFO(还有ANDROID_LOG_ERROR等),表示什么类型
的输出,上面的函数相当于android的java代码的Log.i(LOG_TAG,TITLE),第二个参数就是logcat里的tag,第三个就是打印的内容。具体的请到log.h中自己查看。

可以这样调用
#include <android/log.h>
#define LOG_TAG "libibmphotophun" //定义logcat中tag标签
#define LOGI(...) __android_log_print(ANDROID_LOG_INFO,LOG_TAG,__VA_ARGS__)
//Log().i
#define LOGE(...) __android_log_print(ANDROID_LOG_ERROR,LOG_TAG,__VA_ARGS__)
//Log().e

调用时LOGI("test tag");
本回答被网友采纳
已赞过 已踩过<
你对这个回答的评价是?
评论 收起
zcd96014
2013-02-13 · TA获得超过3894个赞
知道大有可为答主
回答量:2.5万
采纳率:0%
帮助的人:5111万
展开全部
JNI使用LOGD LOGE,LOGV和功能的注意,包括“cutils / log.h”,和一些Java的变量依次,有的不转也可以。
已赞过 已踩过<
你对这个回答的评价是?
评论 收起
收起 更多回答(2)
推荐律师服务: 若未解决您的问题,请您详细描述您的问题,通过百度律临进行免费专业咨询

为你推荐:

下载百度知道APP,抢鲜体验
使用百度知道APP,立即抢鲜体验。你的手机镜头里或许有别人想知道的答案。
扫描二维码下载
×

类别

我们会通过消息、邮箱等方式尽快将举报结果通知您。

说明

0/200

提交
取消

辅 助

模 式