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

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

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

瀏覽:150日期: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免费| 国产极品一区| 日韩综合一区二区| 亚洲午夜一级| 婷婷成人综合| 久久久久网站| 日韩免费视频| www成人在线视频| 视频小说一区二区| 亚洲不卡系列| 午夜精品成人av| 伊人久久高清| 久久久久久久久丰满| 精品国产麻豆| 成人高清一区| 99久久婷婷| av中文字幕在线观看第一页| 国内不卡的一区二区三区中文字幕 | 国产精品二区影院| 精品国产一区二区三区噜噜噜| 高清一区二区三区av| 亚洲欧洲高清| 欧美/亚洲一区| 亚洲免费毛片| 国产精品嫩模av在线| 美女精品久久| 亚洲先锋成人| 日本午夜精品久久久久| 国产免费播放一区二区| 日韩福利视频一区| 国产精品黄网站| 亚洲深夜视频| 亚洲精品一区二区在线播放∴| 国产福利亚洲| 日韩一区亚洲二区| 亚洲精品一区二区在线播放∴| 久久国产精品美女| 不卡在线一区二区| 日韩黄色免费网站| 成人在线视频中文字幕| 宅男噜噜噜66国产日韩在线观看| 亚洲精品在线二区| 久久99蜜桃| 久久精品1区| 婷婷亚洲成人| 99精品美女| 精品资源在线| 久久国产精品久久久久久电车 | 日本亚洲欧洲无免费码在线| 三级在线看中文字幕完整版| 蜜臀av亚洲一区中文字幕| 黄在线观看免费网站ktv| 日韩手机在线| 国产婷婷精品| 亚洲福利一区| 国产精品tv| 日本亚州欧洲精品不卡| 国产一区二区三区视频在线| 日韩中出av| 亚洲欧洲日本mm| 国产亚洲一区二区手机在线观看| 麻豆成人在线观看| 亚洲丝袜美腿一区| 99精品小视频| 国产超碰精品| 成人日韩av| 麻豆成人av在线| 国产欧美日韩精品一区二区免费| 亚洲精品电影| 妖精视频成人观看www| 亚洲午夜精品久久久久久app| 亚洲欧洲高清| 最近高清中文在线字幕在线观看1| 国产欧美在线| 免费一级欧美片在线观看网站| 日韩国产在线观看| 日韩精品一区二区三区av| 热久久久久久久| 午夜精品婷婷| 亚洲精品黄色| 69堂免费精品视频在线播放| 日本精品在线播放| 欧美日韩一区自拍| 久久久免费人体| 日韩欧美中文| 国产麻豆久久| 一区在线免费| 香蕉久久精品| 四虎成人精品一区二区免费网站| 日本亚洲视频| 日本一区二区高清不卡| 另类中文字幕国产精品| 亚洲精品极品少妇16p| 亚洲欧美视频| 日韩精品1区2区3区| 国产不卡精品在线| 久久理论电影| 亚洲日韩中文字幕一区| 日本va欧美va精品| 国产成人免费视频网站视频社区| 激情综合在线| 日韩高清中文字幕一区| 久久精品一区二区三区中文字幕| 91亚洲一区| 99国产精品久久久久久久 | 日韩一级欧洲| 捆绑调教美女网站视频一区| 99综合视频| 精品国产乱码| 亚洲一区二区日韩| 精品视频在线你懂得| 亚洲免费毛片| 亚洲一级在线| 久久精品国产www456c0m| 欧美极品中文字幕| 中文字幕亚洲影视| 色在线中文字幕| 日本成人在线网站| 中文字幕av一区二区三区四区| 日韩啪啪电影网| 风间由美中文字幕在线看视频国产欧美| 久热综合在线亚洲精品| 蜜臀av免费一区二区三区| 亚洲综合电影| 国产v日韩v欧美v| 四虎成人精品一区二区免费网站 | 亚洲精品人人| 日韩精品久久久久久| 久久亚洲国产| 欧美一级网址| 国产一级一区二区| 日本韩国欧美超级黄在线观看| 性欧美长视频| 欧美日韩在线网站| 亚洲一级二级| 久久国产直播| 精品一区二区三区亚洲 | 中文一区二区| 福利精品一区| 国产精品三p一区二区| 亚洲国产一区二区三区在线播放| 久久国产日韩| 成人在线观看免费视频| 国产亚洲字幕| 国产亚洲电影| 亚洲乱码久久| 亚洲伊人精品酒店| 麻豆成人在线| 一区二区亚洲视频| 久久国产麻豆精品| 国产精品高潮呻吟久久久久| 国产精品videossex久久发布 | 午夜亚洲一区| 香蕉久久久久久久av网站| 在线亚洲欧美| 亚洲一区日韩在线| 亚洲tv在线| 7777精品| 精品美女在线视频| 亚洲第一精品影视| 亚洲综合国产| 99热免费精品| 亚洲美女久久| 久久一区精品| 日韩欧美一区二区三区在线观看| 国产精品久久久久蜜臀| 欧美精品资源| 亚洲综合丁香| 欧美1区2区3| 成人久久久久| 亚洲精品婷婷| 黄色aa久久| 麻豆精品视频在线观看视频| 成人精品天堂一区二区三区| 黄页网站一区| 亚洲精选91| 国产精品美女久久久久久不卡| 日韩中文在线播放| 亚洲另类黄色| 欧美国产专区| 日韩伦理在线一区| 美日韩精品视频| 91亚洲国产| 欧美亚洲三区| 红桃视频亚洲| 97精品视频在线看| 亚洲精品乱码久久久久久蜜桃麻豆 | 欧美一级网站| 秋霞影视一区二区三区| 日本少妇一区二区| 黄色在线网站噜噜噜| 亚洲视频电影在线| 欧美一区久久久| 五月天久久777| 精品美女视频| 欧美一级久久| 在线观看一区| 99精品在线免费在线观看|