LogCatUtil——Android中打印文件名、方法名、行数的LogCatUtil

package com.xinwei.palmhall.util;

import java.text.SimpleDateFormat;
import java.util.Date;

import android.util.Log;

public class LogCatUtil {
	private static final boolean DEBUG = true;

	public static void d(String TAG, String method, String msg) {
		if (DEBUG) {
			Log.d(TAG, "[" + method + "]" + msg);
		}
	}

	public static void d(String TAG, String msg) {
		if (DEBUG) {
			Log.d(TAG, "[" + getFileLineMethod() + "]" + msg);
		}
	}

	public static void e(String TAG, String method, String msg) {
		if (DEBUG) {
			Log.e(TAG, "[" + method + "]" + msg);
		}
	}

	public static void e(String TAG, String msg) {
		if (DEBUG) {
			Log.e(TAG, "[" + getFileLineMethod() + "]" + msg);
		}
	}

	public static void i(String TAG, String method, String msg) {
		if (DEBUG) {
			Log.i(TAG, "[" + method + "]" + msg);
		}
	}

	public static void i(String TAG, String msg) {
		if (DEBUG) {
			Log.i(TAG, "[" + getFileLineMethod() + "]" + msg);
		}
	}

	public static void w(String TAG, String method, String msg) {
		if (DEBUG) {
			Log.w(TAG, "[" + method + "]" + msg);
		}
	}

	public static void w(String TAG, String msg) {
		if (DEBUG) {
			Log.w(TAG, "[" + getFileLineMethod() + "]" + msg);
		}
	}

	// 获取文件、行数
	private static String getFileLineMethod() {
		StackTraceElement traceElement = ((new Exception()).getStackTrace())[2];
		StringBuffer toStringBuffer = new StringBuffer("[")
				.append(traceElement.getFileName()).append(" | ")
				.append(traceElement.getLineNumber()).append(" | ")
				.append(traceElement.getMethodName()).append("]");
		return toStringBuffer.toString();
	}

	// 获取行数
	public static String getLineMethod() {
		StackTraceElement traceElement = ((new Exception()).getStackTrace())[2];
		StringBuffer toStringBuffer = new StringBuffer("[")
				.append(traceElement.getLineNumber()).append(" | ")
				.append(traceElement.getMethodName()).append("]");
		return toStringBuffer.toString();
	}

	// 获取文件名
	public static String _FILE_() {
		StackTraceElement traceElement = ((new Exception()).getStackTrace())[2];
		return traceElement.getFileName();
	}

	// 获取方法名
	public static String _FUNC_() {
		StackTraceElement traceElement = ((new Exception()).getStackTrace())[1];
		return traceElement.getMethodName();
	}

	// 获取行数
	public static int _LINE_() {
		StackTraceElement traceElement = ((new Exception()).getStackTrace())[1];
		return traceElement.getLineNumber();
	}

	// 获取时间
	public static String _TIME_() {
		Date now = new Date();
		SimpleDateFormat sdf = new SimpleDateFormat("yyyy-MM-dd HH:mm:ss.SSS");
		return sdf.format(now);
	}
}

本文是在 懒惰日志打印器基础上进行改进的,向原作者致敬


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

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值