zoukankan      html  css  js  c++  java
  • Android 最简单的测试UI卡顿

    就两个类:

    public class BlockDetectByPrinter {
    private static final String START = ">>>>> Dispatching";
    private static final String END = "<<<<< Finished";
    public static void start(){
    Looper.getMainLooper().setMessageLogging(new Printer() {
    @Override
    public void println(String x) {
    if(x.startsWith(START)){
    LogMonitor.getsInstance().startMonitor();
    }
    if(x.startsWith(END)){
    LogMonitor.getsInstance().startMonitor();
    }
    }
    });
    }
    }


    public class LogMonitor {
    private static LogMonitor sInstance = new LogMonitor();
    private HandlerThread mLogThread = new HandlerThread("log");
    private Handler mIoHandler;
    private static final long TIME_BLOCK = 2000L;

    private LogMonitor(){
    mLogThread.start();
    mIoHandler = new Handler(mLogThread.getLooper());
    }
    private static Runnable mLogRunnable = new Runnable() {
    @Override
    public void run() {
    StringBuilder sb = new StringBuilder();
    StackTraceElement[] stackTrace = Looper.getMainLooper().getThread().getStackTrace();
    for(StackTraceElement s:stackTrace){
    sb.append(s.toString()+" ");
    }
    LogUtil.e("LogMonitor",sb.toString());
    }
    };
    public static LogMonitor getsInstance(){
    return sInstance;
    }
    // public boolean isMonitor(){
    // return mIoHandler.hasCallbacks(mLogRunnable);
    // }
    public void startMonitor(){
    mIoHandler.postDelayed(mLogRunnable,TIME_BLOCK);
    }
    public void removeMonitor(){
    mIoHandler.removeCallbacks(mLogRunnable);
    }

    }
    然后在application的onCreate方法使用
    BlockDetectByPrinter.start();



  • 相关阅读:
    java冒泡排序
    正则表达式手册
    简单介绍事务
    Java经典编程30题(中)
    Java经典编程30题(下)
    负载均衡-Nginx
    react入门
    Mybatis && Mybatis-plus
    java设计模式-委派模式
    java8新特性
  • 原文地址:https://www.cnblogs.com/xiaoxiaing/p/7865366.html
Copyright © 2011-2022 走看看