Prevent garbage collection of simple task

pull/155/head
M66B 7 years ago
parent 3e1ac2bef9
commit 06e1fc0674

@ -32,6 +32,8 @@ import androidx.lifecycle.LifecycleOwner;
import androidx.lifecycle.LifecycleService; import androidx.lifecycle.LifecycleService;
import androidx.lifecycle.OnLifecycleEvent; import androidx.lifecycle.OnLifecycleEvent;
import java.util.ArrayList;
import java.util.List;
import java.util.concurrent.ExecutorService; import java.util.concurrent.ExecutorService;
import java.util.concurrent.Executors; import java.util.concurrent.Executors;
@ -42,9 +44,9 @@ import java.util.concurrent.Executors;
// //
public abstract class SimpleTask<T> implements LifecycleObserver { public abstract class SimpleTask<T> implements LifecycleObserver {
private Handler handler = new Handler(); private static final List<SimpleTask> tasks = new ArrayList<>();
private static ExecutorService executor = Executors.newFixedThreadPool( private static final ExecutorService executor = Executors.newFixedThreadPool(
Runtime.getRuntime().availableProcessors(), Helper.backgroundThreadFactory); Runtime.getRuntime().availableProcessors(), Helper.backgroundThreadFactory);
public void execute(Context context, LifecycleOwner owner, @NonNull Bundle args, @NonNull String name) { public void execute(Context context, LifecycleOwner owner, @NonNull Bundle args, @NonNull String name) {
@ -68,6 +70,13 @@ public abstract class SimpleTask<T> implements LifecycleObserver {
} }
private void run(final Context context, final LifecycleOwner owner, final Bundle args, final String name) { private void run(final Context context, final LifecycleOwner owner, final Bundle args, final String name) {
final Handler handler = new Handler();
// prevent garbage collection
synchronized (tasks) {
tasks.add(this);
}
try { try {
onPreExecute(args); onPreExecute(args);
} catch (Throwable ex) { } catch (Throwable ex) {
@ -92,22 +101,27 @@ public abstract class SimpleTask<T> implements LifecycleObserver {
@Override @Override
public void run() { public void run() {
Lifecycle.State state = owner.getLifecycle().getCurrentState(); Lifecycle.State state = owner.getLifecycle().getCurrentState();
if (state.isAtLeast(Lifecycle.State.RESUMED)) { if (state.equals(Lifecycle.State.DESTROYED))
cleanup();
else if (state.isAtLeast(Lifecycle.State.RESUMED)) {
Log.i("Deliver task " + name); Log.i("Deliver task " + name);
deliver(result, args); deliver(result, args);
} else if (!state.equals(Lifecycle.State.DESTROYED)) cleanup();
} else
owner.getLifecycle().addObserver(new LifecycleObserver() { owner.getLifecycle().addObserver(new LifecycleObserver() {
@OnLifecycleEvent(Lifecycle.Event.ON_RESUME) @OnLifecycleEvent(Lifecycle.Event.ON_RESUME)
public void onResume() { public void onResume() {
deliver(result, args);
Log.i("Resume task " + name); Log.i("Resume task " + name);
owner.getLifecycle().removeObserver(this); owner.getLifecycle().removeObserver(this);
deliver(result, args);
cleanup();
} }
@OnLifecycleEvent(Lifecycle.Event.ON_DESTROY) @OnLifecycleEvent(Lifecycle.Event.ON_DESTROY)
public void onDestroyed() { public void onDestroyed() {
Log.i("Destroy task " + name); Log.i("Destroy task " + name);
owner.getLifecycle().removeObserver(this); owner.getLifecycle().removeObserver(this);
cleanup();
} }
}); });
} }
@ -133,6 +147,13 @@ public abstract class SimpleTask<T> implements LifecycleObserver {
} }
} }
private void cleanup() {
synchronized (tasks) {
tasks.remove(this);
Log.i("Remaining tasks=" + tasks.size());
}
}
protected void onPreExecute(Bundle args) { protected void onPreExecute(Bundle args) {
} }

Loading…
Cancel
Save