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