鸿蒙Hilog与Android log分析

Log总览

  • Android Log
  1. Android java层和native层 log
  2. main log、system log、radio log、event log
  • Kernel Log
  1. Linux Kernel内核和驱动log
  2. UART Log
  • Exception Datebase(db)

系统死机/重启等问题发生时候的原始RAW datajava

Log Tools

LocalSocket实现进程间通信

android下使用localsocket可以实现C与C,C与JAVA,JAVA与JAVA进程间通信。

localsocket是linux下的一种本地套接字,用来进行进程间通信,分为非命名和命名两种类型,非命名本地套接字只能用在父子进程之间通信(其实是只有保存了未命名的套接字的文件描述符的进程可以使用),命名套接字则没有这个限制。android在linux的本地套接字上进行封装。

android上使用localsocket主要是通过name来区分,也就是说客户端和服务端之间连接必须使用相同的name,并且一个name同一时间只能有一个服务端运行,name可以只一串字符串,如“com.penguin.sk”。

c客户端代码主要调用的是android接口:

int socket_local_server(const char *name, int namespaceId, int type)

函数读写id,read id就是接收服务端的数据,write id就是发送数据给服务端– 参数name就是上述说的客户端与服务端连接的关键name,namespaceId一般使用ANDROID_SOCKET_NAMESPACE_ABSTRACT, type 使用SOCK_STREAM。

2.2 main log分类

系统根据log类型,分为main,radio,events,system,crash

frameworks/base/core/java/android/util/Log.java //用于记录main log

frameworks/base/core/java/android/util/Slog.java //用于记录framework log

frameworks/base/telephony/java/android/telephony/Rlog.java //用于记录radio log

frameworks/base/core/java/com/android/internal/os/RuntimeInit.java //内部记录了crash log

main指的就是  /dev/log/main这个循环buffer
ls发现
/dev/log/还有这几个循环buffer,一般读取main就够了

system  radio  events  main

 

 

 

 鸿蒙Hilog:目前从代码看,很多功能未实现完......

 

 

 

用户态Process通过日志接口将日志内容写入hilogd buffer中,用户态的hilog工具支持将输出到控制台(console)进行查看,同时也支持通过hilog工具给hilogd发送命令将日志落盘。

 

 

 

 

 

 

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值