日本不卡不码高清免费观看,久久国产精品久久w女人spa,黄色aa久久,三上悠亚国产精品一区二区三区

您的位置:首頁技術文章
文章詳情頁

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

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

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

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

補充知識:android 日志文件LogUtils

背景

這是好久之前在網上找的一個常用類,已經忘記原文鏈接了,但是覺得很好用一直都在用,可以將日志寫到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,設置為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是字符數量不是字節數量所以為了防止中文字符過多,// 把4*1024的MAX字節打印長度改為2001字符數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();}}}}/** * 根據文件路徑 遞歸創建文件 * * @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進行封裝的操作就是小編分享給大家的全部內容了,希望能給大家一個參考,也希望大家多多支持好吧啦網。

標簽: Android
相關文章:
日本不卡不码高清免费观看,久久国产精品久久w女人spa,黄色aa久久,三上悠亚国产精品一区二区三区
欧美日韩国产精品一区二区亚洲| 亚洲区欧美区| 嫩呦国产一区二区三区av| 亚洲一区二区三区久久久| 日韩制服丝袜av| 免费在线观看精品| 亚洲在线久久| 亚洲精品激情| 日韩国产精品久久久| 色8久久久久| 欧美中文日韩| 一区二区三区四区日韩| 亚洲开心激情| 欧美亚洲福利| 久久只有精品| 日韩视频网站在线观看| 日韩在线短视频| 亚洲女同中文字幕| 亚洲在线网站| 伊人精品久久| 国产午夜久久av| 国产精品毛片久久久| 国产精品jk白丝蜜臀av小说| 久久精品一区二区国产| 久久精品国产99国产| 欧美激情麻豆| 日韩免费高清| 99精品99| 欧美日本一区| 大香伊人久久精品一区二区| 精品福利久久久| 青青久久av| 亚洲欧美日韩在线观看a三区| 亚洲1区在线观看| 国产精品qvod| 久久精品青草| 久久性天堂网| 国产精品欧美在线观看| 亚洲最新无码中文字幕久久 | 欧美日韩视频网站| 欧美日韩视频| 日本少妇精品亚洲第一区| 久久久久伊人| 日韩精品影视| 蜜芽一区二区三区| 久久影院一区二区三区| 性欧美xxxx免费岛国不卡电影| 亚洲在线久久| 色爱综合网欧美| 亚洲专区欧美专区| 九九99久久精品在免费线bt| 久久精品成人| 亚洲一区区二区| 久久av电影| 亚洲网站视频| 日韩高清成人在线| 欧美成a人国产精品高清乱码在线观看片在线观看久 | 精品免费av在线| 蜜桃视频一区二区三区| 精品亚洲二区| 免费视频久久| 国产91在线精品| 最新国产精品| 久久精品资源| 蜜臀久久99精品久久久久久9| 你懂的国产精品永久在线| 国产主播一区| 国产探花一区在线观看| 999久久久精品国产| 91精品日本| 国产精品99一区二区| 国产精品4hu.www| 亚洲制服少妇| 日韩欧美一区免费| 91精品国产自产观看在线| 日韩精品一区二区三区免费观看| 欧美一级久久| 夜夜精品视频| 欧美交a欧美精品喷水| 99在线精品免费视频九九视| 久久97视频| 日韩一区二区三区免费视频| 午夜欧美巨大性欧美巨大| 日韩高清电影一区| 91久久黄色| 中文字幕人成乱码在线观看| 亚洲免费成人av在线| 丝袜av一区| 国产精品精品国产一区二区| 亚洲精品日本| 亚洲女同中文字幕| 免费高潮视频95在线观看网站| 国产日韩1区| 最新日韩欧美| 久久91导航| 精品丝袜久久| 91精品福利观看| 久久国产精品久久w女人spa| 欧美午夜精品一区二区三区电影| 成人国产综合| 国产精品一线| 日韩和欧美的一区| 香蕉久久久久久久av网站| 日韩一区二区在线免费| 麻豆精品视频在线观看| 国产图片一区| 欧美午夜三级| 日韩黄色免费网站| 噜噜噜久久亚洲精品国产品小说| 久久蜜桃资源一区二区老牛| 国产精品精品| 动漫av一区| 精品黄色一级片| 欧美激情在线精品一区二区三区| 日韩**一区毛片| 亚洲网址在线观看| 亚洲综合精品四区| 婷婷精品进入| 亚洲网站视频| 日韩天堂av| 午夜久久福利| 婷婷亚洲五月| 国产精品美女久久久| 色综合www| 国产美女高潮在线观看| 高清一区二区| 水蜜桃精品av一区二区| 精品理论电影在线| 国产一区二区三区不卡av| 久久精品国产在热久久| 麻豆国产91在线播放| 国产精品美女午夜爽爽| 国产麻豆一区二区三区精品视频| 91欧美日韩在线| 欧美欧美黄在线二区| 欧美日韩亚洲一区在线观看| 欧美片网站免费| 久久国产免费看| 欧美日本不卡| 国产精品入口久久| 国产一区二区三区四区五区| 日本一区二区免费高清| 性欧美videohd高精| 久久一区二区三区电影| 国产一区亚洲| 久久国产88| 青青草伊人久久| 精品五月天堂| 亚洲二区在线| 鲁大师成人一区二区三区| 中文字幕av一区二区三区四区| 亚洲精品乱码| 国产精品一线| 久久精品免视看国产成人| 精品视频自拍| 日韩在线欧美| 波多野结衣一区| 亚洲精选av| 久久在线91| 亚洲小说欧美另类婷婷| 香蕉久久夜色精品国产| 亚洲1区在线| 麻豆免费精品视频| 特黄毛片在线观看| 午夜精品影院| 91精品国产自产精品男人的天堂 | 97精品资源在线观看| 国产精品115| 日韩久久一区二区三区| 国产精品视区| 欧美三区不卡| se01亚洲视频 | 日韩影院在线观看| 国产欧美日韩在线观看视频| 麻豆成人av在线| 久久精品免费一区二区三区| 石原莉奈在线亚洲二区| 国产欧美日韩综合一区在线播放| 特黄毛片在线观看| 蜜桃av一区二区| 麻豆精品国产91久久久久久| 亚洲国产综合在线看不卡| 日韩精品一级中文字幕精品视频免费观看 | 日韩午夜一区| 亚洲综合福利| 国产成人精品999在线观看| 午夜视频精品| 国产欧美成人| 国产一区日韩一区| 国产免费av国片精品草莓男男| 久久精品观看| 国产日韩视频| 亚洲作爱视频| 国产成人调教视频在线观看| 久久成人亚洲| 久久久久久久欧美精品| 精品国产a一区二区三区v免费| 中文字幕av亚洲精品一部二部| 日本欧美国产| 欧美日韩1区|