Android log 源码分析

Android log 源码分析

什么是缓存区

缓冲区是logd 进程所拥有的, 也就是说所有log 都在logd 进程进行缓存

log的写入

android 系统常用有两种log写入,一种是java -logd ,一种是c++/c -logd

Android log 大体框架是 c/s 框架。所以研究Android log系统,分成两个部分 ( 以下是基于java测到logd的描述)

Android log 是如何从应用进程 写入logd进程的
(1) java测log写法:Log.d();
(2) log.d 调用jni android_util_Log_println_native_id 函数调用liblog(__android_log_buf_write_id)的接口
(3) liblog 通过logdw 向logd 进程写入log信息
(4)logd进程接收log信息存入缓存区;
3.2 Android log 是如何从log的进程 读取数据到logcat 进程的
App 通过logcat 进程读取logd进程读取log信息
logcat 通过logdr向logd进程发送读log请求,并等待接收log信息
logd进程解析log信息读取请求,从缓存区读出log信息通过logdr传回logcat进程;
logcat最后再对读出的log信息做相关处理,打印至终端或者文件。

参考资料

https://jekton.github.io/2018/05/11/logd-overview/
https://blog.csdn.net/kc58236582/article/details/51506896
https://blog.csdn.net/loongembedded/article/details/78500005

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值