从网上摘抄的,很方便。
package com.hanya.financing.global.utils;
import android.util.Log;
import com.hanya.financing.global.WalrusApplication;
public class DebugUtil {
public static boolean DEBUG = WalrusApplication.isShowLog;
public static String className;
private DebugUtil() {
}
public static boolean isDebugEnable() {
return DEBUG;
}
private static String createLog(String log) {
return log;
}
private static void getMethodNames(StackTraceElement[] sElements) {
String methodName = sElements[1].getMethodName();
int lineNumber = sElements[1].getLineNumber();
className = "{ " + sElements[1].getFileName() + " : " + lineNumber + " - " + methodName + " }";
}
public static void e(String message) {
if (!isDebugEnable())
return;
getMethodNames(new Throwable().getStackTrace());
Log.e(className, createLog(message));
}
public static void e(String tag, String message, Throwable throwable) {
if (!isDebugEnable()) {
return;
}
Log.e(tag, message, throwable);
}
public static void e(String Tag, String message) {
if (!isDebugEnable())
return;
getMethodNames(new Throwable().getStackTrace());
Log.e(Tag, createLog(message));
}
public static void i(String message) {
if (!isDebugEnable())
return;
getMethodNames(new Throwable().getStackTrace());
Log.i(className, createLog(message));
}
public static void d(String message) {
if (!isDebugEnable())
return;
getMethodNames(new Throwable().getStackTrace());
Log.d(className, createLog(message));
}
public static void v(String message) {
if (!isDebugEnable())
return;
getMethodNames(new Throwable().getStackTrace());
Log.v(className, createLog(message));
}
public static void w(String message) {
if (!isDebugEnable())
return;
getMethodNames(new Throwable().getStackTrace());
Log.w(className, createLog(message));
}
public static void wtf(String message) {
if (!isDebugEnable())
return;
getMethodNames(new Throwable().getStackTrace());
Log.wtf(className, createLog(message));
}
public static void debug(String tag, Object searchManager) {
if (isDebugEnable()) {
Log.d(tag, searchManager.toString());
}
}
public static void trace(String s) {
if (isDebugEnable()) {
Log.v("", s);
}
}
public static void warn(String tag, Object intent) {
if (isDebugEnable()) {
Log.e(tag, intent.toString());
}
}
/**
* 该类提供格式化JSON字符串的方法。
* 该类的方法formatJson将JSON字符串格式化,方便查看JSON数据。
* <p>例如:
* <p>JSON字符串:["yht","xzj","zwy"]
* <p>格式化为:
* <p>[
* <p> "yht",
* <p> "xzj",
* <p> "zwy"
* <p>]
* <p/>
* <p>使用算法如下:
* <p>对输入字符串,追个字符的遍历
* <p>1、获取当前字符。
* <p>2、如果当前字符是前方括号、前花括号做如下处理:
* <p>(1)如果前面还有字符,并且字符为“:”,打印:换行和缩进字符字符串。
* <p>(2)打印:当前字符。
* <p>(3)前方括号、前花括号,的后面必须换行。打印:换行。
* <p>(4)每出现一次前方括号、前花括号;缩进次数增加一次。打印:新行缩进。
* <p>(5)进行下一次循环。
* <p>3、如果当前字符是后方括号、后花括号做如下处理:
* <p>(1)后方括号、后花括号,的前面必须换行。打印:换行。
* <p>(2)每出现一次后方括号、后花括号;缩进次数减少一次。打印:缩进。
* <p>(3)打印:当前字符。
* <p>(4)如果当前字符后面还有字符,并且字符不为“,”,打印:换行。
* <p>(5)继续下一次循环。
* <p>4、如果当前字符是逗号。逗号后面换行,并缩进,不改变缩进次数。
* <p>5、打印:当前字符。
*
* @author yanghaitao
* @version [版本号, 2014年9月29日]
*/
public static class JsonFormatTool {
/**
* 单位缩进字符串。
*/
private static String SPACE = " ";
/**
* 返回格式化JSON字符串。
*
* @param json 未格式化的JSON字符串。
* @return 格式化的JSON字符串。
*/
public String formatJson(String json) {
StringBuilder result = new StringBuilder();
int length = json.length();
int number = 0;
char key;
//遍历输入字符串。
for (int i = 0; i < length; i++) {
//1、获取当前字符。
key = json.charAt(i);
//2、如果当前字符是前方括号、前花括号做如下处理:
if ((key == '[') || (key == '{')) {
//(1)如果前面还有字符,并且字符为“:”,打印:换行和缩进字符字符串。
if ((i - 1 > 0) && (json.charAt(i - 1) == ':')) {
result.append('\n');
result.append(indent(number));
}
//(2)打印:当前字符。
result.append(key);
//(3)前方括号、前花括号,的后面必须换行。打印:换行。
result.append('\n');
//(4)每出现一次前方括号、前花括号;缩进次数增加一次。打印:新行缩进。
number++;
result.append(indent(number));
//(5)进行下一次循环。
continue;
}
//3、如果当前字符是后方括号、后花括号做如下处理:
if ((key == ']') || (key == '}')) {
//(1)后方括号、后花括号,的前面必须换行。打印:换行。
result.append('\n');
//(2)每出现一次后方括号、后花括号;缩进次数减少一次。打印:缩进。
number--;
result.append(indent(number));
//(3)打印:当前字符。
result.append(key);
//(4)如果当前字符后面还有字符,并且字符不为“,”,打印:换行。
if (((i + 1) < length) && (json.charAt(i + 1) != ',')) {
result.append('\n');
}
//(5)继续下一次循环。
continue;
}
//4、如果当前字符是逗号。逗号后面换行,并缩进,不改变缩进次数。
if ((key == ',')) {
result.append(key);
result.append('\n');
result.append(indent(number));
continue;
}
//5、打印:当前字符。
result.append(key);
}
return result.toString();
}
/**
* 返回指定次数的缩进字符串。每一次缩进三个空格,即SPACE。
*
* @param number 缩进次数。
* @return 指定缩进次数的字符串。
*/
private String indent(int number) {
StringBuilder result = new StringBuilder();
for (int i = 0; i < number; i++) {
result.append(SPACE);
}
return result.toString();
}
}
}