Android_NDK调试

第一步:

链接log动态库

在Android.mk文件中添加

LOCAL_LDLIBS +=-llog

注意:一定要在

复制代码
include $(BUILD_SHARED_LIBRARY)

之上添加,因为当执行到这句话的时候就表示所有的lib动态库已经加载完毕了,所以当你在这句代码之后再添加链接动态库的命令时,动态库是加载不成功的,当执行ndk-build时,会报链接不到动态库的错误

第二步:

在对应的CPP文件中添加

复制代码
#include <android/log.h>

第三步:

在CPP文件中使用__android_log_print函数打印日志

该函数有三个参数,第一个为打印日志的类型取值有:

ANDROID_LOG_DEFAULT,

ANDROID_LOG_VERBOSE,

ANDROID_LOG_DEBUG,

ANDROID_LOG_INFO,

ANDROID_LOG_WARN,

ANDROID_LOG_ERROR,

ANDROID_LOG_FATAL,

ANDROID_LOG_SILENT

第二个为自定义的日志的Tag

第三个为可变参数,输出的日志信息

建议定义宏使用,如下:

#ifndef LOG_TAG

#define LOG_TAG "my_tag"

#define LOGINFO(...) __android_log_print(ANDROID_LOG_INFO,LOG_TAG,VA_ARGS)

#define LOGERR(...) __android_log_print(ANDROID_LOG_ERROR,LOG_TAG,VA_ARGS)

Char* str = "my info";

LOGINFO("配置信息:%s", str);

第四步:

重新ndk-build一下CPP程序

第五步:

重新Refresh Linked C++ projects

相关推荐
2601_9495430118 分钟前
Flutter for OpenHarmony垃圾分类指南App实战:主题配置实现
android·flutter
2601_949833391 小时前
flutter_for_openharmony口腔护理app实战+知识实现
android·javascript·flutter
晚霞的不甘1 小时前
Flutter for OpenHarmony从基础到专业:深度解析新版番茄钟的倒计时优化
android·flutter·ui·正则表达式·前端框架·鸿蒙
鸟儿不吃草2 小时前
android的Retrofit请求https://192.168.43.73:8080/报错:Handshake failed
android·retrofit
Minilinux20182 小时前
Android音频系列(09)-AudioPolicyManager代码解析
android·音视频·apm·audiopolicy·音频策略
李子红了时2 小时前
【无标题】
android
Android系统攻城狮4 小时前
Android tinyalsa深度解析之pcm_close调用流程与实战(一百零四)
android·pcm·tinyalsa·音频进阶·音频性能实战·android hal
weixin_411191844 小时前
LifecycleEventObserver和DefaultLifecycleObserver使用
android
、BeYourself4 小时前
Intent :跳转与数据传递的正确打开方式
android·android-studio
灵感菇_4 小时前
Android 列表控件全面解析:ListView 与 RecyclerView
android·ui