Android Log(一) 自定义带类名与方法名的Log

        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



  • 0
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值