前几天突然发现修改后的app运行起来很卡顿,使用Android studio的Profile也看不出个所以然来,于是对比了一下前面版本的代码,发现问题所在:
mNaviHandler.postDelayed(mRecThread, 5000);
mRecThread是一个一直在后台运行的线程,本来是想让其启动延迟一些(因为有些线程需要跑在前面),与是利用现存的handler给它postdelay了一下,却没注意到,Handler.post的Runnable其实是运行在主线中的。
请看Handler的默认构造函数:
public Handler() {
this(null, false);
}
public Handler(@Nullable Callback callback, boolean async) {
if (FIND_POTENTIAL_LEAKS) {
final Class<? extends Handler> klass = getClass();
if ((klass.isAnonymousClass() || klass.isMemberClass() || klass.isLocalClass()) &&
(klass.getModifiers() & Modifier.STATIC) == 0) {
Log.w(TAG, "The following Handler class should be static or leaks might occur: " +
klass.getCanonicalName());