文档章节

Android开发中调试日志的输出方法

我希冀着
 我希冀着
发布于 2016/07/22 16:35
字数 698
阅读 63
收藏 1

程序中输出日志, 使用 android.util.Log 类. 
该类提供了若干静态方法

Log.v(String tag, String msg); 
Log.d(String tag, String msg); 
Log.i(String tag, String msg); 
Log.w(String tag, String msg); 
Log.e(String tag, String msg);

分别对应 Verbose, Debug, Info, Warning,Error.

tag是一个标识,可以是任意字符串,通常可以使用类名+方法名, 主要是用来在查看日志时提供一个筛选条件.

如果要后查看日志 请使用

adb logcat

关于adb的更多信息请查看官方网站.

当执行 adb logcat 后会以tail方式实时显示出所有的日志信息.

这时候我们通常需要对信息进行过滤,来显示我们需要的信息, 这时候我们指定的 tag就派上了用场.

adb logcat -s MyAndroid:I

这时将只显示tag为MyAndroid,级别为I或级别高于I(Warning,Error)的日志信息.

logcat使用方法如下所示: 
logcat [options] [filterspecs]
logcat的选项包括:
  -s                    设置过滤器,例如指定 '*:s'
  -f <filename>   输出到文件,默认情况是标准输出。
  -r [<kbytes>]   Rotate log every kbytes. (16 if unspecified). Requires -f
  -n <count>      Sets max number of rotated logs to <count>, default 4
  -v <format>     设置log的打印格式,  <format> 是下面的一种:
                         brief process tag thread raw time threadtime long

  -c                   清除所有log并退出
  -d                   得到所有log并退出 (不阻塞)
  -g                   得到环形缓冲区的大小并退出
  -b <buffer>     请求不同的环形缓冲区    ('main' (默认), 'radio', 'events')
  -B                   输出log到二进制中。

过滤器的格式是一个这样的串:
  <tag>[:priority]

其中 <tag> 表示log的component, tag (或者使用 * 表示所有) , priority 如下所示:
  V    Verbose
  D    Debug
  I    Info
  W    Warn
  E    Error
  F    Fatal
  S    Silent

导出日志:adb logcat -d -f /sdcard/log.txt

常用命令如下:

(1) 显示全部日志信息:adb logcat

(2) 显示某一TAG的日志信息:adb logcat -s TAG名称

(3) 显示某一TAG的某一级别的日志信息:adb logcat TAG名称:级别.....TAG名称:级别 *:S

  注:日志级别(V-verbose,D-debug,I-info,W-warning,E-error,F-fatal,S-silent),*:S(确保日志输出的时候是按照过滤器的说明限制)

(4) 显示某一级别以上的全部日志信息:adb logcat *:级别

(5) 以某种格式显示日志信息:adb logcat -v 格式

  注:日志格式(brief,process,tag,thread,raw,time,long)

(6) 显示缓冲区中的日志信息:adb logcat -b 缓冲区类型

  注:缓冲区类型(radio-无线缓冲区,events-事件缓冲区,main-主缓冲区,默认)

(7) 清理已经存在的日志:adb logcat -c

(8) 将日志显示在控制台后退出:adb logcat -d

(9) 将日志输出到文件:adb logcat -f 文件名

© 著作权归作者所有

共有 人打赏支持
我希冀着

我希冀着

粉丝 70
博文 44
码字总数 26777
作品 0
厦门
Android工程师
私信 提问
Windows环境下Android Studio系列5—日志调试

定制Logcat调试日志字体颜色 Logcat是Android开发调试中最常用的一个工具,Android Studio 1.2.2中默认对Logcat调试的颜色已经有所区分,但如果你想要定制自己的调试日志对应的字体颜色,以便...

一配
2015/07/15
0
1
使用Android开发方便快捷的8 个好工具

Android是目前最流行的移动操作系统之一,Android应用开发目前也正变得越来越流行。这里有8个最好的 Android工具,在这些工具的帮助下,开发人员可以更方便、快捷地开发应用程序。 1. SDK和A...

android技术开发
2013/07/29
69
0
eclipse信息输出区没有logcat的解决方法

有时候会莫名其妙的就找不到输出信息区的LogCat日志了,很郁闷。![LogCat输出区示意图][1] 解决方法:Eclipse菜单栏中【Windows--->Show Views】弹层中选择LogCat,如果找不到则点击最下方的...

bukw
2013/12/14
0
0
Eclipse中做Android开发LogCat的使用

介绍LogCat是Eclipse里面做Android开发的工具包ADT中的一个工具,用来查看和过滤Android日志系统的输出。 打开LogCat 进入Eclipse,选择Window菜单,然后选择Show View子菜单,最后再选则oth...

LeoXu
2015/07/16
0
0
Android单元测试与日志输出

使用单元测试可以保证我们开发的应用质量, 一般我们开发完业务层后对业务层进行测试,确保业务层不会出现bug,对业务层通过之后控制层就可以调用业务层 完成所需的功能。 以前做Java开发的时...

晨曦之光
2012/05/16
395
0

没有更多内容

加载失败,请刷新页面

加载更多

websocket 接口简单测试工具,webcoket实用测试工具

chorme 插件 Simple WebSocket Client 对开发来说够用了,能连互联网,也能连本地的。

SimonAt
5分钟前
0
0
Ext中 get、getDom、getCmp的区别

getDom方法能够得到文档中的DOM节点,该方法中包含一个参数,该参数可以是DOM节点的id、DOM节点对象或DOM节点对应的Ext元素(Element)等。 (与getElementById是一个效果) •Ext.onReady(funct...

休辞醉倒
13分钟前
0
0
springboot jpa 访问数据库

spring boot(五):spring data jpa的使用 SpringBoot非官方教程 | 第三篇:SpringBoot用JdbcTemplates访问Mysql

颖辉小居
27分钟前
4
0
Quartz + Oracle 分布式Job实现

简述 实现 依赖包 <dependency><groupId>org.quartz-scheduler</groupId><artifactId>quartz</artifactId><version>2.2.3</version><exclusions><exclusion><groupId>com.zax......

呼呼南风
33分钟前
5
0
崛起于Springboot2.X之集成规则引擎Drools(41)

1、创建Springboot项目,勾选Web模块和lombok插件 2、添加pom其他依赖 <dependency> <groupId>org.kie</groupId> <artifactId>kie-spring</artifactId> <version>7.11.0.Fin......

木九天
41分钟前
5
0

没有更多内容

加载失败,请刷新页面

加载更多

返回顶部
顶部