我正在使用一个在侦听器事件上取消并重新启动的计时器。除了计时器线程泄漏整个外部类之外,一切都工作正常。
我的定时器实现如下:
if(timer != null) {
timer.cancel();
timer = null;
timer = new Timer();
}
timer.schedule(new TimerTask() { // Thread leaks!!!!
@Override
public void run() {
mCallback.onHeaderMoving(newToolbarTranslationY );
}
} , 150);
我使用 MAT 分析器来追踪问题并最终解决了这个问题。我还用回调注释掉了该行,但线程仍然泄漏,因此它肯定是计时器本身。但是我真的不明白该代码有什么问题。
据我从我的研究中了解到,问题在于匿名内部类(new Timertask())持有对外部类的引用,因此可能会泄漏整个上下文。但我仍然不明白为什么计时器以及对上下文的引用在线程耗尽后(150 毫秒以上)不会被垃圾收集。
在这种情况下,即使线程完成后,上下文是否仍然没有释放?
最后我该如何解决这个泄漏?我将计时器设置为空,但这并没有解决我的问题。
Edit
private OnHeaderMovingCallBack mCallback;
private Timer timer = new Timer();
//... some other parameters
public ScrollingToolbarManager(View toolbar , View pagerStrip , AbsListView listView , OnHeaderMovingCallBack headerMovingCallBack){
this.toolbar = toolbar;
this.pagerStrip = pagerStrip;
this.listView = listView;
mCallback = headerMovingCallBack;
changeStartValues();
}
public static interface OnHeaderMovingCallBack{
public void onHeaderMoving(int translationY);
}
public void moveHeader(){
//... some calculations
//timer implementation from above
}
moveHeader() 在列表视图的滚动事件上调用