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. linux无锁化编程--__sync_fetch_and_add系列原子操作函数

    linux支持的哪些操作是具有原子特性的?知道这些东西是理解和设计无锁化编程算法的基础. 下面的东西整理自网络.先感谢大家的分享! __sync_fetch_and_add系列的命令,发现这个系列命令 ...

  2. stm32 优先级说明

    抢占优先级和响应优先级.事实上是一个中断所包括的两个优先级,当中前者是对抢占优先级的级别划分,后者是同样抢占优先级的优先级别的划分. 比方: 中断A抢占优先级比B高,那么A的中断能够在B里面触发,忽略 ...

  3. Revit API判断直线相交关系移动风管

    start )             );         )) )) );         XYZ xyz12 = lCurve1.Curve.get_EndPoint();         XY ...

  4. 这里包含几乎所有的xcode正式版本

    https://developer.apple.com/downloads/

  5. 怎样用javascript获取UUID

    因为javascript是单线程的东西,所以我们放一个累加变量作为id也不会反复. 但事实上javascript本身提供了能够获得唯一id的东东.还记得setTimeout()方法会返回一个唯一id用 ...

  6. 最简单的例子理解Javascript闭包

    理解Javascript的闭包非常关键,本篇试图用最简单的例子理解此概念. function greet(sth){ return function(name){ console.log(sth + ...

  7. #ifdef #else #endif 的用法

    预处理就是在进行编译的第一遍词法扫描和语法分析之前所作的工作.说白了,就是对源文件进行编译前,先对预处理部分进行处理,然后对处理后的代码进行编译.这样做的好处是,经过处理后的代码,将会变的很精短. 关 ...

  8. sqlite 字符串 转 整型 cast 函数 (强制类型转换 )

    sqlite 字符串 转 整型使用 cast 函数 语法: cast(col_name as type) 例子: 表:JobInfo 表内字段:Salary  薪水 select * from Job ...

  9. 神探夏洛克第一季/全集Sherlock1迅雷下载

    第一季 Sherlock Season 1 (2010)看点:夏洛克·福尔摩斯(Sherlock Holmes)是一个虚构的侦探人物,是由19世纪末的英国侦探小说家阿瑟·柯南·道尔所塑造的一个才华横溢 ...

  10. tomcat站点配置

    那么只需要在tomcat 上下文中声明 <Parameter name=“log4j.org.springframework.orm” value=“debug”/> 1.server.x ...