Android中的Log我们经常用到,使我们调试程序起来更加方便快捷。但如果出现太多的log,如果我们不加一些标识的话,调试起来也十分的头疼。下面我们来写带类名与方法名的LogUtil,使我们调试时能快速定位到代码位置。下面是代码:
public class LogUtil {
private static final String TAG = "LogUtil";
//Log开关
private static final boolean DEBUG = true;
public static void d(String message) {
if (DEBUG)Log.d(TAG, createMessage(message));
}
public static void e(String message) {
if (DEBUG) Log.e(TAG, createMessage(message));
}
public static void i(String message) {
if (DEBUG) Log.i(TAG, createMessage(message) );
}
public static void v(String message) {
if (DEBUG) Log.v(TAG, createMessage(message));
}
public static void w(String message) {
if (DEBUG)Log.w(TAG, createMessage(message));
}
public static void wtf(String message) {
if (DEBUG) Log.wtf(TAG, createMessage(message));
}
public static void println(String message) {
if (DEBUG) Log.println(Log.INFO, TAG, message);
}
/**
* 获取有类名与方法名的logString
* @param rawMessage
* @return
*/
private static String createMessage(String rawMessage) {
/**
* Throwable().getStackTrace()获取的是程序运行的堆栈信息,也就是程序运行到此处的流程,以及所有方法的信息
* 这里我们为什么取2呢?0是代表createMessage方法信息,1是代表上一层方法的信息,这里我们
* 取它是上两层方法的信息
*/
StackTraceElement stackTraceElement = new Throwable().getStackTrace()[2];
String fullClassName = stackTraceElement.getClassName();
String className = fullClassName.substring(fullClassName.lastIndexOf(".") + 1);
return className + "." + stackTraceElement.getMethodName() + "(): " + rawMessage;
}
}
我们做一下测试,测试代码如下:
public class MainActivity extends AppCompatActivity implements View.OnClickListener{
@Override
protected void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
setContentView(R.layout.activity_main);
findViewById(R.id.btn).setOnClickListener(this);
}
@Override
public void onClick(View view) {
switch (view.getId()){
case R.id.btn:
testLog();
break;
}
}
private void testLog() {
LogUtil.e("====test log");
}
}
测试结果如:
MainActivity .
testLog():
====test log