android logcat详解及缓存

16lz 2021-01-24

Android日志系统提供了记录和查看系统调试信息的功能。日志都是从各种软件和一些系统的缓冲区中记录下来的,缓冲区可以通过 logcat 命令来查看和使用.


使用logcat 命令
你可以用 logcat 命令来查看系统日志缓冲区的内容:

[adb] logcat
[<option>] ... [<filter-spec>] ...请查看Listing of logcat Command Options ,它对logcat 命令有详细的描述 .

你也可以在你的电脑或运行在模拟器/设备上的远程adb shell端来使用logcat 命令,也可以在你的电脑上查看日志输出。

$ adb logcat
你也这样使用:

# logcat

过滤日志输出
每一个输出的Android日志信息都有一个标签和它的优先级.

•日志的标签是系统部件原始信息的一个简要的标志。(比如:“View”就是查看系统的标签).
•优先级有下列集中,是按照从低到高顺利排列的:
•V — Verbose (lowest priority)
•D — Debug
•I — Info
•W — Warning
•E — Error
•F — Fatal
•S — Silent (highest priority, on which nothing is ever printed)
在运行logcat 的时候在前两列的信息中你就可以看到 logcat 的标签列表和优先级别,它是这样标出的:<priority>/<tag> .

下面是一个logcat 输出的例子,它的优先级就似乎I,标签就是ActivityManage:

I/ActivityManager( 585): Starting activity: Intent { action=android.intent.action...}为了让日志输出能体现管理的级别,你还可以用过滤器来控制日志输出,过滤器可以帮助你描述系统的标签等级.

过滤器语句按照下面的格式描tag:priority ... , tag 表示是标签,priority 是表示标签的报告的最低等级. 从上面的tag的中可以得到日志的优先级. 你可以在过滤器中多次写tag:priority .

这些说明都只到空白结束。下面有一个列子,例子表示支持所有的日志信息,除了那些标签为”ActivityManager”和优先级为”Info”以上的和标签为” MyApp”和优先级为” Debug”以上的。 小等级,优先权报告为tag.

adb logcat
ActivityManager:I MyApp:D *:S上面表达式的最后的元素 *:S ,,是设置所有的标签为”silent”,所有日志只显示有”View” and “MyApp”的,用 *:S 的另一个用处是 能够确保日志输出的时候是按照过滤器的说明限制的,也让过滤器也作为一项输出到日志中.

下面的过滤语句指显示优先级为warning或更高的日志信息:

adb logcat
*:W如果你电脑上运行logcat ,相比在远程adbshell端,你还可以为环境变量ANDROID_LOG_TAGS :输入一个参数来设置默认的过滤

export ANDROID_LOG_TAGS="ActivityManager:I MyApp:D *:S"需要注意的是ANDROID_LOG_TAGS 过滤器如果通过远程shell运行logcat 或用adb shell logcat 来运行模拟器/设备不能输出日志.


控制日志输出格式
日志信息包括了许多元数据域包括标签和优先级。可以修改日志的输出格式,所以可以显示出特定的元数据域。可以通过 -v 选项得到格式化输出日志的相关信息.

•brief — Display priority/tag and PID of originating process (the default format).
•process — Display PID only.
•tag — Display the priority/tag only.
•thread — Display process:thread and priority/tag only.
•raw — Display the raw log message, with no other metadata fields.
•time — Display the date, invocation time, priority/tag, and PID of the originating process.
•long — Display all metadata fields and separate messages with a blank lines.
当启动了logcat ,你可以通过-v 选项来指定输出格式:

[adb] logcat
[-v <format>]下面是用 thread 来产生的日志格式:

adb logcat
-v thread需要注意的是你只能-v 选项来规定输出格式 option.


查看可用日志缓冲区
Android日志系统有循环缓冲区,并不是所有的日志系统都有默认循环缓冲区。为了得到日志信息,你需要通过-b 选项来启动logcat 。如果要使用循环缓冲区,你需要查看剩余的循环缓冲期:

•radio — 查看缓冲区的相关的信息.
•events — 查看和事件相关的的缓冲区.
•main — 查看主要的日志缓冲区
-b 选项使用方法:

[adb] logcat
[-b <buffer>]下面的例子表示怎么查看日志缓冲区包含radio 和 telephony信息:

adb logcat
-b radio
查看stdout 和stderr
在默认状态下,Android系统有stdout 和 stderr (System.out 和System.err )输出到/dev/null ,在运行Dalvik VM的进程中,有一个系统可以备份日志文件。在这种情况下,系统会用stdout 和stderr 和优先级 I.来记录日志信息

通过这种方法指定输出的路径,停止运行的模拟器/设备,然后通过用setprop 命令远程输入日志

$ adb shell stop
$ adb shell setprop log.redirect-stdio true
$ adb shell start系统直到你关闭模拟器/设备前设置会一直保留,可以通过添加/data/local.prop 可以使用模拟器/设备上的默认设置


Logcat 命令列表
Option Description
-b <buffer> 加载一个可使用的日志缓冲区供查看,比如event 和radio . 默认值是main 。具体查看Viewing Alternative Log Buffers.
-c 清楚屏幕上的日志.
-d 输出日志到屏幕上.
-f <filename> 指定输出日志信息的<filename> ,默认是stdout .
-g 输出指定的日志缓冲区,输出后退出.
-n <count> 设置日志的最大数目<count> .,默认值是4,需要和 -r 选项一起使用。
-r <kbytes> 每<kbytes> 时输出日志,默认值为16,需要和-f 选项一起使用.
-s 设置默认的过滤级别为silent.
-v <format> 设置日志输入格式,默认的是brief 格式,要知道更多的支持的格式,参看Controlling Log Output Format

LogCat的信息是缓存在哪里的?


LogCat的信息量那么大,我想出于性能考虑Android应该是不会把它动态存储在内存中而是缓存在某个系统文件中吧?
请问有这样的文件吗?是哪个文件呢?谢谢...

补充内容 (2011-1-22 14:26):
找到了,是/dev/log/main
这个文件


看了又看 热点讨论 待解决问题
1/1 看了又看 热点讨论 待解决问题
  • 原来是50台电脑的工作组环境,现 ...
  • 域结构下,主DNS和辅助DNS之间的恩怨!~ ...
  • 服务器装系统需注意的几点,给自己 ...
  • 针对域用户禁止USB策略
  • 客户机不能加域
  • 服务器安装系统图示,没有安装过服 ...
  • 想部署域环境,但如何规划?~ ...
  • 关于域的两个精典问题!高手请进!!! ...
1/1 看了又看 热点讨论 待解决问题
1/5

TOP

沙发 大 中 小 发表于 2011-2-1 12:33 只看该作者

弱电安防培训--工信部认证 | 开大会啦!开大会啦!门票免费领! | 票选您最喜欢的IBM DB2最佳特性 | 1下载豆起拍腰轻松按摩枕!


附带个问题:

如何在程序中获取LogCat的输出信息呢?

执行:
Runtime.getRuntime().exec("logcat")
输出提示是:
Unable to open log device '/dev/log/main': Permission denied


谢谢...

TOP

板凳 大 中 小 发表于 2011-2-1 12:39 只看该作者

弱电安防培训--工信部认证 | 开大会啦!开大会啦!门票免费领! | 票选您最喜欢的IBM DB2最佳特性 | 1下载豆起拍腰轻松按摩枕!


唉,有点自问自答的感觉
需要个权限:
<uses-permission android:name="android.permission.READ_LOGS" />

更多相关文章

  1. Android项目开发中如何处理Home键
  2. Android4.4以太网移植问题
  3. Android(安卓)视频播放器 应用层设计 考虑事项 (二)
  4. [Android]Recovery调用外部Shell脚本,Shell脚本使用ui_print方法
  5. Android(安卓)解决方法数 65536 (65k) 限制
  6. Android(安卓)SurfaceFlinger学习文档
  7. Android(安卓)Hugo
  8. radiolog不全的问题
  9. android service 生命周期

随机推荐

  1. Android 常用开发工具类
  2. Android 保存文件路径
  3. Android中设置定时器
  4. Android长按弹出菜单
  5. Android 博客园客户端 (二) 新界面&部分功
  6. Android使adb作为host运行在arm64平台
  7. Android Eclipse JNI 调用 .so文件加载
  8. [Android L]关于Android L的Service启动
  9. android 编译源码 错误解决2
  10. Android 签名类型