亚洲精品久久久中文字幕-亚洲精品久久片久久-亚洲精品久久青草-亚洲精品久久婷婷爱久久婷婷-亚洲精品久久午夜香蕉

您的位置:首頁技術(shù)文章
文章詳情頁

Android封裝對原生Log進行封裝的操作

瀏覽:54日期:2022-09-22 18:59:42

我就廢話不多說了,大家還是直接看代碼吧~

package com.zjx.taobaounion.utils;import android.util.Log;public class LogUtils { private static int currentLev = 4; // 當(dāng)前l(fā)og等級 上線之后控制這個等級 就可以減少Log的輸出 private static final int DEBUG_LEV = 4; // debug 等級 private static final int INFO_LEV = 3; // info 等級 private static final int WARNING_LEV = 2; // warning 等級 private static final int ERROR_LEV = 1; // error 等級 public static void d(Class clazz,String log){ if (currentLev >= DEBUG_LEV) { // 如果當(dāng)前設(shè)置的等級 大于等于 debug等級 那么就證明當(dāng)前不屏蔽debug的log輸出 Log.d(clazz.getSimpleName(),log); } } public static void i(Class clazz,String log){ if (currentLev >= INFO_LEV) { // 如果當(dāng)前設(shè)置的等級 大于等于 info 那么就證明當(dāng)前不屏蔽info的log輸出 Log.i(clazz.getSimpleName(),log); } } public static void w(Class clazz,String log){ if (currentLev >= WARNING_LEV) { // 如果當(dāng)前設(shè)置的等級 大于等于 warning 那么就證明當(dāng)前不屏蔽warning的log輸出 Log.w(clazz.getSimpleName(),log); } } public static void e(Class clazz,String log){ if (currentLev >= ERROR_LEV) { // 如果當(dāng)前設(shè)置的等級 大于等于 error 那么就證明當(dāng)前不屏蔽error的log輸出 Log.e(clazz.getSimpleName(),log); } }}

補充知識:android 日志文件LogUtils

背景

這是好久之前在網(wǎng)上找的一個常用類,已經(jīng)忘記原文鏈接了,但是覺得很好用一直都在用,可以將日志寫到file里面也可以定位你是在哪個類哪一行打印的日志,保存到文件的路徑就是android/data/你的包名/files/目錄下,然后我們就可以愉快的找問題了

import android.text.TextUtils;import android.util.Log;import com.smartlink.suixing.App;import com.smartlink.suixing.BuildConfig;import java.io.BufferedWriter;import java.io.File;import java.io.FileOutputStream;import java.io.IOException;import java.io.OutputStreamWriter;import java.text.SimpleDateFormat;import java.util.Date;import java.util.Formatter;import java.util.Locale;public class LogUtils {public static StringcustomTagPrefix= 'log';// 自定義Tag的前綴,可以是作者名private static final booleanisSaveLog= true;// 是否把保存日志到SD卡中private static StringcacheDirPath;private LogUtils() {}// 容許打印日志的類型,默認是true,設(shè)置為false則不打印public static booleanallowD= BuildConfig.DEBUG;public static booleanallowE= BuildConfig.DEBUG;public static booleanallowI= BuildConfig.DEBUG;public static booleanallowV= BuildConfig.DEBUG;public static booleanallowW= BuildConfig.DEBUG;public static booleanallowWtf= BuildConfig.DEBUG;// public static boolean allowD = true;// public static boolean allowE = true;// public static boolean allowI = true;// public static boolean allowV = true;// public static boolean allowW = true;// public static boolean allowWtf = true;private static String generateTag(StackTraceElement caller) {String tag = '%s.%s(Line:%d)'; // 占位符String callerClazzName = caller.getClassName(); // 獲取到類名callerClazzName = callerClazzName.substring(callerClazzName.lastIndexOf('.') + 1);tag = String.format(tag, callerClazzName, caller.getMethodName(), caller.getLineNumber()); // 替換tag = TextUtils.isEmpty(customTagPrefix) ? tag : customTagPrefix + ':' + tag;return tag;}/*** * 打印控制臺顯示不了那么長的日志問題 * * @param msg */public static void logE(String msg) { // 信息太長,分段打印if (!allowE) return;StackTraceElement caller = getCallerStackTraceElement();String tag = generateTag(caller);// 因為String的length是字符數(shù)量不是字節(jié)數(shù)量所以為了防止中文字符過多,// 把4*1024的MAX字節(jié)打印長度改為2001字符數(shù)int max_str_length = 2001 - tag.length();// 大于4000時while (msg.length() > max_str_length) {// Log.e(tag, msg.substring(0, max_str_length));LogUtils.e(msg.substring(0, max_str_length));msg = msg.substring(max_str_length);}// 剩余部分// Log.e(tag, msg);LogUtils.e(msg);}/** * 自定義的logger */public static CustomLogger customLogger;public interface CustomLogger {void d(String tag, String content);void d(String tag, String content, Throwable tr);void e(String tag, String content);void e(String tag, String content, Throwable tr);void i(String tag, String content);void i(String tag, String content, Throwable tr);void v(String tag, String content);void v(String tag, String content, Throwable tr);void w(String tag, String content);void w(String tag, String content, Throwable tr);void w(String tag, Throwable tr);void wtf(String tag, String content);void wtf(String tag, String content, Throwable tr);void wtf(String tag, Throwable tr);}public static void d(String content) {if (!allowD) return;StackTraceElement caller = getCallerStackTraceElement();String tag = generateTag(caller);if (customLogger != null) {customLogger.d(tag, content);} else {Log.d(tag, content);}}public static void d(String content, Throwable tr) {if (!allowD) return;StackTraceElement caller = getCallerStackTraceElement();String tag = generateTag(caller);if (customLogger != null) {customLogger.d(tag, content, tr);} else {Log.d(tag, content, tr);}}public static void e(String content) {if (!allowE) return;StackTraceElement caller = getCallerStackTraceElement();String tag = generateTag(caller);if (customLogger != null) {customLogger.e(tag, content);} else {Log.e(tag, content);}if (isSaveLog) {point(cacheDirPath, tag, content);}}public static void e(String content, Throwable tr) {if (!allowE) return;StackTraceElement caller = getCallerStackTraceElement();String tag = generateTag(caller);if (customLogger != null) {customLogger.e(tag, content, tr);} else {Log.e(tag, content, tr);}if (isSaveLog) {point(cacheDirPath, tag, tr.getMessage());}}public static void e(Throwable tr) {if (!allowE) return;StackTraceElement caller = getCallerStackTraceElement();String tag = generateTag(caller);if (customLogger != null) {customLogger.e(tag, '', tr);} else {Log.e(tag, '', tr);}if (isSaveLog) {point(cacheDirPath, tag, tr.getMessage());}}public static void i(String content) {if (!allowI) return;StackTraceElement caller = getCallerStackTraceElement();String tag = generateTag(caller);if (customLogger != null) {customLogger.i(tag, content);} else {Log.i(tag, content);}}public static void i(String content, Throwable tr) {if (!allowI) return;StackTraceElement caller = getCallerStackTraceElement();String tag = generateTag(caller);if (customLogger != null) {customLogger.i(tag, content, tr);} else {Log.i(tag, content, tr);}}public static void v(String content) {if (!allowV) return;StackTraceElement caller = getCallerStackTraceElement();String tag = generateTag(caller);if (customLogger != null) {customLogger.v(tag, content);} else {Log.v(tag, content);}}public static void v(String content, Throwable tr) {if (!allowV) return;StackTraceElement caller = getCallerStackTraceElement();String tag = generateTag(caller);if (customLogger != null) {customLogger.v(tag, content, tr);} else {Log.v(tag, content, tr);}}public static void w(String content) {if (!allowW) return;StackTraceElement caller = getCallerStackTraceElement();String tag = generateTag(caller);if (customLogger != null) {customLogger.w(tag, content);} else {Log.w(tag, content);}}public static void w(String content, Throwable tr) {if (!allowW) return;StackTraceElement caller = getCallerStackTraceElement();String tag = generateTag(caller);if (customLogger != null) {customLogger.w(tag, content, tr);} else {Log.w(tag, content, tr);}}public static void w(Throwable tr) {if (!allowW) return;StackTraceElement caller = getCallerStackTraceElement();String tag = generateTag(caller);if (customLogger != null) {customLogger.w(tag, tr);} else {Log.w(tag, tr);}}public static void wtf(String content) {if (!allowWtf) return;StackTraceElement caller = getCallerStackTraceElement();String tag = generateTag(caller);if (customLogger != null) {customLogger.wtf(tag, content);} else {Log.wtf(tag, content);}}public static void wtf(String content, Throwable tr) {if (!allowWtf) return;StackTraceElement caller = getCallerStackTraceElement();String tag = generateTag(caller);if (customLogger != null) {customLogger.wtf(tag, content, tr);} else {Log.wtf(tag, content, tr);}}public static void wtf(Throwable tr) {if (!allowWtf) return;StackTraceElement caller = getCallerStackTraceElement();String tag = generateTag(caller);if (customLogger != null) {customLogger.wtf(tag, tr);} else {Log.wtf(tag, tr);}}private static StackTraceElement getCallerStackTraceElement() {return Thread.currentThread().getStackTrace()[4];}public static void point(String path, String tag, String msg) {if (isSDAva()) {path = cacheDirPath;Date date = new Date();SimpleDateFormat dateFormat = new SimpleDateFormat('', Locale.SIMPLIFIED_CHINESE);dateFormat.applyPattern('yyyy');path = path + dateFormat.format(date) + '/';dateFormat.applyPattern('MM');path += dateFormat.format(date) + '/';dateFormat.applyPattern('dd');path += dateFormat.format(date) + '.log';dateFormat.applyPattern('[yyyy-MM-dd HH:mm:ss]');String time = dateFormat.format(date);File file = new File(path);if (!file.exists()) createDipPath(path);BufferedWriter out = null;try {out = new BufferedWriter(new OutputStreamWriter(new FileOutputStream(file, true)));out.write(time + ' ' + tag + ' ' + msg + 'rn');} catch (Exception e) {e.printStackTrace();} finally {try {if (out != null) {out.close();}} catch (IOException e) {e.printStackTrace();}}}}/** * 根據(jù)文件路徑 遞歸創(chuàng)建文件 * * @param file */public static void createDipPath(String file) {String parentFile = file.substring(0, file.lastIndexOf('/'));File file1 = new File(file);File parent = new File(parentFile);if (!file1.exists()) {parent.mkdirs();try {file1.createNewFile();LogUtils.e('日志文件的路徑是' + file1.getAbsolutePath());} catch (IOException e) {e.printStackTrace();}}}/** * A little trick to reuse a formatter in the same thread */private static class ReusableFormatter {private Formatterformatter;private StringBuilderbuilder;public ReusableFormatter() {builder = new StringBuilder();formatter = new Formatter(builder);}public String format(String msg, Object... args) {formatter.format(msg, args);String s = builder.toString();builder.setLength(0);return s;}}private static final ThreadLocal<ReusableFormatter> thread_local_formatter = new ThreadLocal<ReusableFormatter>() {protected ReusableFormatter initialValue() {return new ReusableFormatter();}};public static String format(String msg, Object... args) {ReusableFormatter formatter = thread_local_formatter.get();return formatter.format(msg, args);}public static boolean isSDAva() {if (cacheDirPath == null) cacheDirPath = App.getAppContext().getExternalFilesDir('log').getAbsolutePath();if (!TextUtils.isEmpty(cacheDirPath)) {return true;} else {return false;}}}

以上這篇Android封裝對原生Log進行封裝的操作就是小編分享給大家的全部內(nèi)容了,希望能給大家一個參考,也希望大家多多支持好吧啦網(wǎng)。

標簽: Android
相關(guān)文章:
主站蜘蛛池模板: 污视频在线观看免费 | 成年黄色片 | 国产日本亚洲欧美 | 好湿好紧好痛a级是免费视频 | 日本特级全黄一级毛片 | 国产成人综合日韩精品婷婷九月 | 亚洲精品免费网站 | 国产黄色片91 | 国产页| 久久黄色毛片 | 天天拍夜夜操 | 中国内地毛片免费高清 | 欧美国产高清 | a级毛片免费高清毛片视频 a级毛片免费播放 | 九九热国产视频 | 久久久久中文字幕 | 银杏视频影院在线看 | 91午夜影院| 欧美日产欧美日产精品 | 久久中文精品 | 亚洲免费成人 | 国产午夜精品视频 | 一区二区不卡 | 国产精品视频一区二区三区经 | 亚洲最大看欧美片网站 | 日本不卡毛片一二三四 | 免费日韩视频 | 日本黄色免费在线观看 | 免费黄色网页 | 黑人一区 | 欧美制服丝袜在线 | 青青草国产青春综合久久 | 九九在线视频 | 黄色天堂网站 | 欧美精品国产一区二区三区 | 久久精品在线 | 新香蕉视频 | 极品美女一级毛片免费 | 玖玖爱在线观看视频在线 | 尤物精品视频在线观看 | 国产精品久久福利新婚之夜 |