| |
|
开发:
C++知识库
Java知识库
JavaScript
Python
PHP知识库
人工智能
区块链
大数据
移动开发
嵌入式
开发工具
数据结构与算法
开发测试
游戏开发
网络协议
系统运维
教程: HTML教程 CSS教程 JavaScript教程 Go语言教程 JQuery教程 VUE教程 VUE3教程 Bootstrap教程 SQL数据库教程 C语言教程 C++教程 Java教程 Python教程 Python3教程 C#教程 数码: 电脑 笔记本 显卡 显示器 固态硬盘 硬盘 耳机 手机 iphone vivo oppo 小米 华为 单反 装机 图拉丁 |
-> 移动开发 -> Android系统10 RK3399 init进程启动(十七) Verbose日志级别打开方式 -> 正文阅读 |
|
[移动开发]Android系统10 RK3399 init进程启动(十七) Verbose日志级别打开方式 |
配套系列教学视频链接:? ? ??安卓系列教程之ROM系统开发-百问100ask 说明系统:Android10.0 设备: FireFly RK3399 (ROC-RK3399-PC-PLUS) 前言Android系统中C/C++代码中verbose级别的日志是不会输出,是因为一个开关没打开,本节就给大家介绍如何打开这个开关。 一, 介绍在底层调试系统代码时,?会有ALOGV级别代码, 这些在调试的时候能帮我们看到更加详细的日志,这样更方便我们去理解系统代码,比如app_process程序: 但是C/C++代码中的ALOGV()一般虽然调用了, 通过logcat一般也是看不到的,是什么原因的,可以查看log/log_main.h中
以上代码可以看到定义了两个接口: 1, __ALOGV()==>ALOG() 2, ALOGV()==>__ALOGV() 同时LOG_NDEBUG为1时, ALOGV实际是一个空函数, 那LOG_NDEBUG默认是多少呢? 而LOG_NDEBUG的定义由如下控制:
以上代码可以知道: 默认LOG_NDEBUG没有定义,如果NDEBUG定义了, LOG_NDEBUG就为1 (ALOGV()为空) 通过搜索grep -rHn "NDEBUG" ./build, 编译系统会自动定义NDEBUG, 所以LOG_NDEBUG也就默认为1
所以如果要想LOG_NDEBUG为0: 只需要做:
Android.bp可以加cflags: ["-UNDEBUG"] Android.mk 可以加 LOCAL_C_FLAG := -UUNDEBUG ?二,总结:Java层verbose的日志是可以打印的,对于C/C++代码, 根据自己的需求,打开verbose开关,就能查看系统中的进程的更多日志。 |
|
移动开发 最新文章 |
Vue3装载axios和element-ui |
android adb cmd |
【xcode】Xcode常用快捷键与技巧 |
Android开发中的线程池使用 |
Java 和 Android 的 Base64 |
Android 测试文字编码格式 |
微信小程序支付 |
安卓权限记录 |
知乎之自动养号 |
【Android Jetpack】DataStore |
|
上一篇文章 下一篇文章 查看所有文章 |
|
开发:
C++知识库
Java知识库
JavaScript
Python
PHP知识库
人工智能
区块链
大数据
移动开发
嵌入式
开发工具
数据结构与算法
开发测试
游戏开发
网络协议
系统运维
教程: HTML教程 CSS教程 JavaScript教程 Go语言教程 JQuery教程 VUE教程 VUE3教程 Bootstrap教程 SQL数据库教程 C语言教程 C++教程 Java教程 Python教程 Python3教程 C#教程 数码: 电脑 笔记本 显卡 显示器 固态硬盘 硬盘 耳机 手机 iphone vivo oppo 小米 华为 单反 装机 图拉丁 |
360图书馆 购物 三丰科技 阅读网 日历 万年历 2024年11日历 | -2024/11/24 16:52:42- |
|
网站联系: qq:121756557 email:121756557@qq.com IT数码 |