android.util.Log常用的方法有以下5个:

Log.v() Log.d() Log.i() Log.w() 以及 Log.e()。根据首字母分别对应VERBOSE,DEBUG,INFO,WARN,ERROR。

1、Log.v 的调试颜色为黑色的,任何消息都会输出,这里的v代表verbose啰嗦的意思,平时使用就是Log.v("","");

2、Log.d的输出颜色是蓝色的,仅输出debug调试的意思,但他会输出上层的信息,过滤起来可以通过DDMS的Logcat标签来选择。

3、Log.i的输出为绿色,一般提示性的消息information,它不会输出Log.v和Log.d的信息,但会显示i、w和e的信息。

4、Log.w的意思为橙色,可以看作为warning警告,一般需要我们注意优化Android代码,同时选择它后还会输出Log.e的信息。

5、Log.e为红色,可以想到error错误,这里仅显示红色的错误信息,这些错误就需要我们认真的分析,查看栈的信息了。

  1 public class MyLog {
2 private static Boolean MYLOG_SWITCH = true; // 日志文件总开关 3 private static Boolean MYLOG_WRITE_TO_FILE = true;// 日志写入文件开关 4 private static char MYLOG_TYPE = 'v';// 输入日志类型,w代表只输出告警信息等,v代表输出所有信息 5 private static String MYLOG_PATH_SDCARD_DIR = "/sdcard/";// 日志文件在sdcard中的路径 6 private static int SDCARD_LOG_FILE_SAVE_DAYS = 0;// sd卡中日志文件的最多保存天数 7 private static String MYLOGFILEName = "Log.txt";// 本类输出的日志文件名称 8 private static SimpleDateFormat myLogSdf = new SimpleDateFormat(
9 "yyyy-MM-dd HH:mm:ss");// 日志的输出格式 10 private static SimpleDateFormat logfile = new SimpleDateFormat("yyyy-MM-dd");// 日志文件格式 11 public Context context;
12 13 public static void w(String tag, Object msg) { // 警告信息 14 log(tag, msg.toString(), 'w');
15 }
16 17 public static void e(String tag, Object msg) { // 错误信息 18 log(tag, msg.toString(), 'e');
19 }
20 21 public static void d(String tag, Object msg) {// 调试信息 22 log(tag, msg.toString(), 'd');
23 }
24 25 public static void i(String tag, Object msg) {//
26 log(tag, msg.toString(), 'i');
27 }
28 29 public static void v(String tag, Object msg) {
30 log(tag, msg.toString(), 'v');
31 }
32 33 public static void w(String tag, String text) {
34 log(tag, text, 'w');
35 }
36 37 public static void e(String tag, String text) {
38 log(tag, text, 'e');
39 }
40 41 public static void d(String tag, String text) {
42 log(tag, text, 'd');
43 }
44 45 public static void i(String tag, String text) {
46 log(tag, text, 'i');
47 }
48 49 public static void v(String tag, String text) {
50 log(tag, text, 'v');
51 }
52 53 /** 54 * 根据tag, msg和等级,输出日志
55 *
56 * @param tag
57 * @param msg
58 * @param level
59 * @return void
60 * @since v 1.0
61 */ 62 private static void log(String tag, String msg, char level) {
63 if (MYLOG_SWITCH) {
64 if ('e' == level && ('e' == MYLOG_TYPE || 'v' == MYLOG_TYPE)) { // 输出错误信息 65 Log.e(tag, msg);
66 } else if ('w' == level && ('w' == MYLOG_TYPE || 'v' == MYLOG_TYPE)) {
67 Log.w(tag, msg);
68 } else if ('d' == level && ('d' == MYLOG_TYPE || 'v' == MYLOG_TYPE)) {
69 Log.d(tag, msg);
70 } else if ('i' == level && ('d' == MYLOG_TYPE || 'v' == MYLOG_TYPE)) {
71 Log.i(tag, msg);
72 } else {
73 Log.v(tag, msg);
74 }
75 if (MYLOG_WRITE_TO_FILE)
76 writeLogtoFile(String.valueOf(level), tag, msg);
77 }
78 }
79 80 /** 81 * 打开日志文件并写入日志
82 *
83 * @return 84 * **/ 85 private static void writeLogtoFile(String mylogtype, String tag, String text) {// 新建或打开日志文件 86 Date nowtime = new Date();
87 String needWriteFiel = logfile.format(nowtime);
88 String needWriteMessage = myLogSdf.format(nowtime) + " " + mylogtype
89 + " " + tag + " " + text;
90 File dirPath = Environment.getExternalStorageDirectory();
91 File file = new File(dirPath.toString(), needWriteFiel + MYLOGFILEName);// MYLOG_PATH_SDCARD_DIR 92 try {
93 FileWriter filerWriter = new FileWriter(file, true);// 后面这个参数代表是不是要接上文件中原来的数据,不进行覆盖 94 BufferedWriter bufWriter = new BufferedWriter(filerWriter);
95 bufWriter.write(needWriteMessage);
96 bufWriter.newLine();
97 bufWriter.close();
98 filerWriter.close();
99 } catch (IOException e) {
100 e.printStackTrace();
101 }
102 }
103104 /**105 * 删除制定的日志文件
106 * */107 public static void delFile() {// 删除日志文件108 String needDelFiel = logfile.format(getDateBefore());
109 File dirPath = Environment.getExternalStorageDirectory();
110 File file = new File(dirPath, needDelFiel + MYLOGFILEName);// MYLOG_PATH_SDCARD_DIR111 if (file.exists()) {
112 file.delete();
113 }
114 }
115116 /**117 * 得到现在时间前的几天日期,用来得到需要删除的日志文件名
118 * */119 private static Date getDateBefore() {
120 Date nowtime = new Date();
121 Calendar now = Calendar.getInstance();
122 now.setTime(nowtime);
123 now.set(Calendar.DATE, now.get(Calendar.DATE)
124 - SDCARD_LOG_FILE_SAVE_DAYS);
125 return now.getTime();
126 }
127 }

注:还需要在AndroidManifest.xml文件中添加权限
<uses-permission android:name="android.permission.WRITE_EXTERNAL_STORAGE" />

Android输出日志Log类的更多相关文章

  1. Android输出日志Log类并保存到文件中

    android.util.Log常用的方法有以下5个: Log.v() Log.d() Log.i() Log.w() 以及 Log.e().根据首字母分别对应VERBOSE,DEBUG,INFO,W ...

  2. Android学习笔记Log类输出日志信息

    Log类提供的方法 代码示例 .. Log.e(TAG,"[错误信息]"); Log.w(TAG,"[警告信息]"); Log.i(TAG,"[普通信 ...

  3. Android输出日志到电脑磁盘

    使用Eclipse查看Log有时候挺恶心的,有些Log ADB会自动的清除,所有有时候导致抓不到有效的Log,把Log保存到文件,然后通过文本查看器查看,感觉好Happy,下面就是脚本文件: adb ...

  4. android 代码优化:关闭输出日志

    android关闭日志 我们在开发时,经常会输出各种日志来debug代码.但是等到应用发布的apk运行时不希望它输出日志. 关闭输出日志Log.v(),Log.i(),Log.w(),Log.v(), ...

  5. Android Log类基本用法

    Log类介绍: API for sending log output.Generally, use the Log.v() Log.d() Log.i() Log.w() and Log.e() me ...

  6. android关闭日志

    我们在开发时,经常会输出各种日志来debug代码.但是等到应用发布的apk运行时不希望它输出日志. 关闭输出日志Log.v(),Log.i(),Log.w(),Log.v(),Log.e()等 原理: ...

  7. log4j2分层输出日志

    在java mvc框架开发过程中,我们经常的将代码分为类似controller(控制层).service(业务层).rpc(远程接口调用层).dao(数据层)等层级,如果将所有层级的日志全部都打到一个 ...

  8. Android学习笔记——log无法输出的解决方法和命令行查看log日志

    本人邮箱:JohnTsai.Work@gmail.com,欢迎交流讨论. 欢迎转载,转载请注明网址:http://www.cnblogs.com/JohnTsai/p/3983936.html. 知识 ...

  9. 关于android的日志输出&LogCat

    android提供了自己的log输出api-->位于android.util.Log这个类中. 这个类比较常用的打印日志的方法有5个,这5个方法都会把日志打印到LogCat中: Log.v(ta ...

随机推荐

  1. [Winform]只允许运行一个exe,如果已运行则将窗口置前

    摘要 接着介绍项目中用到的一些方法,在winform中,打好包,有时并不允许运行多个客户端,要保证只有一个客户端运行.如果已经运行了,则弹出已运行的窗口,使其展示. 方法 判断是否有相同的进程 /// ...

  2. lodash用法系列(5),链式

    Lodash用来操作对象和集合,比Underscore拥有更多的功能和更好的性能. 官网:https://lodash.com/引用:<script src="//cdnjs.clou ...

  3. 【python】python读写文件,都不乱码

    读是按照文本的编码方式读取,写是按照文本的编码方式追加 import chardet fileName = 'E:/2/采集数据_pswf12_180大0小35750_20181206.txt' # ...

  4. ibatis.net:第六天,QueryForList

    xml <statement id="FindOrdersByCustomer" parameterClass="string" resultClass= ...

  5. Linux学习17-gitlab访问慢502问题优化

    前言 浏览器访问gitlab的web页面,发现非常慢,并且很容易出现502问题.其中一个原因就是8080端口被tomcat占用,前面一篇已经更换了端口,但还是很慢. 后来搜了下,原因是gitlab占用 ...

  6. SharePoint Online 创建图片库

    前言 本文介绍如何在Office 365中创建图片库,以及图片库的一些基本设置. 正文 通过登录地址登录到Office 365的SharePoint Online站点中,我们可以在右上角的设置菜单中, ...

  7. 分布式系统唯一ID生成方案汇总 转

    系统唯一ID是我们在设计一个系统的时候常常会遇见的问题,也常常为这个问题而纠结.生成ID的方法有很多,适应不同的场景.需求以及性能要求.所以有些比较复杂的系统会有多个ID生成的策略.下面就介绍一些常见 ...

  8. 零基础写python爬虫之使用Scrapy框架编写爬虫

    网络爬虫,是在网上进行数据抓取的程序,使用它能够抓取特定网页的HTML数据.虽然我们利用一些库开发一个爬虫程序,但是使用框架可以大大提高效率,缩短开发时间.Scrapy是一个使用Python编写的,轻 ...

  9. CentOS Virtual Machine 设置SSH主机登录

    查看Centos7的IP 我们输入ip查询命名 ip addr  也可以输入 ifconfig查看ip,但此命令会出现3个条目,centos的ip地址是ens33条目中的inet值. 发现 ens33 ...

  10. [转]XCache 3.0.0 发布,PHP 性能提升方案

    From : http://www.oschina.net/news/34304/xcache-3-0-0 XCache 3.0.0 发布,该版本除了 bug 修复,对 XCache 管理页面做了很多 ...