Log.d(mTag, msg);
}
}
/** 以级别为 i 的形式输出LOG */
public static void i(String msg) {
if (mDebuggable >= LEVEL_INFO) {
Log.i(mTag, msg);
}
}
/** 以级别为 w 的形式输出LOG */
public static void w(String msg) {
if (mDebuggable >= LEVEL_WARN) {
Log.w(mTag, msg);
}
}
/** 以级别为 w 的形式输出Throwable */
public static void w(Throwable tr) {
if (mDebuggable >= LEVEL_WARN) {
Log.w(mTag, “”, tr);
}
}
/** 以级别为 w 的形式输出LOG信息和Throwable */
public static void w(String msg, Throwable tr) {
if (mDebuggable >= LEVEL_WARN && null != msg) {
Log.w(mTag, msg, tr);
}
}
/** 以级别为 e 的形式输出LOG */
public static void e(String msg) {
if (mDebuggable >= LEVEL_ERROR) {
Log.e(mTag, msg);
}
}
/** 以级别为 e 的形式输出Throwable */
public static void e(Throwable tr) {
if (mDebuggable >= LEVEL_ERROR) {
Log.e(mTag, “”, tr);
}
}
/** 以级别为 e 的形式输出LOG信息和Throwable */
public static void e(String msg, Throwable tr) {
if (mDebuggable >= LEVEL_ERROR && null != msg) {
Log.e(mTag, msg, tr);
}
}
/**
-
以级别为 e 的形式输出msg信息,附带时间戳,用于输出一个时间段起始点
-
@param msg
-
需要输出的msg
*/
public static void msgStartTime(String msg) {
mTimestamp = System.currentTimeMillis();
if (!TextUtils.isEmpty(msg)) {
e(“[Started:” + mTimestamp + “]” + msg);
}
}
/** 以级别为 e 的形式输出msg信息,附带时间戳,用于输出一个时间段结束点* @param msg 需要输出的msg */
public static void elapsed(String msg) {
long currentTime = System.currentTimeMillis();
long elapsedTime = currentTime - mTimestamp;
mTimestamp = currentTime;
e(“[Elapsed:” + elapsedTime + “]” + msg);
}
public static void printList(List list) {
if (list == null || list.size() < 1) {
return;
}
int size = list.size();
i(“—begin—”);
for (int i = 0; i < size; i++) {
i(i + “:” + list.get(i).toString());
}
i(“—end—”);
}
public static void printArray(T[] array) {
if (array == null || array.length < 1) {
return;
}
int length = array.length;
i(“—begin—”);
for (int i = 0; i < length; i++) {
i(i + “:” + array[i].toString());
}
i(“—end—”);
}
public static void LogMap(Map<String, String> args){
if(AppConfig.IS_LOG&&args!=null){
for(Map.Entry<String,String> entry:args.entrySet()){
Log.i(entry.getKey(),entry.getValue());
}
}
}
public static void LogObj(Object object){
if(AppConfig.IS_LOG&&object!=null){
Log.i(“getData: **”, JsonUtil.toJson(object));
}
}
}
AppConfig.java
public class AppConfig {
public static final boolean DEBUG = true;//测试
public static final String URI_BASE = DEBUG?“http://www.xxx.com:xxx/”:“http://xx.xxx.xxx.xxx:xxx/”;;
public static final String URL = “http://xxx.xxx.x.xxx:xxxx/Handler1.ashx/”;
public static final boolean IS_LOG = DEBUG;
}
最后
自我介绍一下,小编13年上海交大毕业,曾经在小公司待过,也去过华为、OPPO等大厂,18年进入阿里一直到现在。
深知大多数初中级Android工程师,想要提升技能,往往是自己摸索成长,自己不成体系的自学效果低效漫长且无助。
因此我收集整理了一份《2024年Android移动开发全套学习资料》,初衷也很简单,就是希望能够帮助到想自学提升又不知道该从何学起的朋友,同时减轻大家的负担。
既有适合小白学习的零基础资料,也有适合3年以上经验的小伙伴深入学习提升的进阶课程,基本涵盖了95%以上Android开发知识点!不论你是刚入门Android开发的新手,还是希望在技术上不断提升的资深开发者,这些资料都将为你打开新的学习之门
如果你觉得这些内容对你有帮助,需要这份全套学习资料的朋友可以戳我获取!!
由于文件比较大,这里只是将部分目录截图出来,每个节点里面都包含大厂面经、学习笔记、源码讲义、实战项目、讲解视频,并且会持续更新!
习的零基础资料,也有适合3年以上经验的小伙伴深入学习提升的进阶课程,基本涵盖了95%以上Android开发知识点!不论你是刚入门Android开发的新手,还是希望在技术上不断提升的资深开发者,这些资料都将为你打开新的学习之门**
如果你觉得这些内容对你有帮助,需要这份全套学习资料的朋友可以戳我获取!!
由于文件比较大,这里只是将部分目录截图出来,每个节点里面都包含大厂面经、学习笔记、源码讲义、实战项目、讲解视频,并且会持续更新!