You can not select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.

164 lines
3.8 KiB

/*
* Copyright (c) Facebook, Inc. and its affiliates.
*
* This source code is licensed under the MIT license found in the
* LICENSE file in the root directory of this source tree.
*/
import android.os.Binder;
import android.os.RemoteException;
import java.util.concurrent.Callable;
import java.util.concurrent.Executor;
import java.util.concurrent.ExecutorService;
import java.util.concurrent.ScheduledExecutorService;
import java.util.concurrent.TimeUnit;
class ModeledExecutors {
static Binder binder;
private static void doTransact() {
try {
binder.transact(0, null, null, 0);
} catch (RemoteException e) {
}
}
public void postBlockingCallToForegroundExecutorOk() {
Executors.getForegroundExecutor()
.execute(
new Runnable() {
@Override
public void run() {
doTransact();
}
});
}
public void postBlockingCallToBackgroundExecutorOk() {
Executors.getBackgroundExecutor()
.execute(
new Runnable() {
@Override
public void run() {
doTransact();
}
});
}
// starvation via posting a transaction on UI thread
public void staticPostBlockingCallToUIThreadBad() {
Executors.postOnUiThread(
new Runnable() {
@Override
public void run() {
doTransact();
}
});
}
// starvation via running a transaction on UI thread
public void staticRunBlockingCallToUIThreadBad() {
Executors.runOnUiThread(
new Runnable() {
@Override
public void run() {
doTransact();
}
});
}
// starvation via running a delayed transaction on UI thread
public void staticPostDelayedBlockingCallToUIThreadBad() {
Executors.postOnUiThreadDelayed(
new Runnable() {
@Override
public void run() {
doTransact();
}
},
1000L);
}
public void scheduleGuaranteedDelayedBlockingCallToNonUIThreadOk() {
Executors.scheduleGuaranteedDelayed(
new Runnable() {
@Override
public void run() {
doTransact();
}
},
1000L,
1000L);
}
Object monitorA, monitorB;
public void scheduleGuaranteedDelayedDeadlockBad() {
Executors.scheduleGuaranteedDelayed(
new Runnable() {
@Override
public void run() {
synchronized (monitorA) {
synchronized (monitorB) {
}
}
}
},
1000L,
1000L);
Executors.runOnUiThread(
new Runnable() {
@Override
public void run() {
synchronized (monitorB) {
synchronized (monitorA) {
}
}
}
});
}
@ForUiThread private final Executor mUiThreadExecutor = null;
public void submitBlockingCallToUIThreadBad() {
ExecutorService uiExecutor = (ExecutorService) mUiThreadExecutor;
uiExecutor.submit(
new Runnable() {
@Override
public void run() {
doTransact();
}
});
}
public void scheduleBlockingCallToUIThreadBad() {
ScheduledExecutorService uiExecutor = (ScheduledExecutorService) mUiThreadExecutor;
uiExecutor.schedule(
new Runnable() {
@Override
public void run() {
doTransact();
}
},
1000L,
TimeUnit.SECONDS);
}
public void submitBadCallableToUIThreadBad() {
ExecutorService uiExecutor = (ExecutorService) mUiThreadExecutor;
uiExecutor.submit(
new Callable<Object>() {
@Override
public Object call() {
doTransact();
return null;
}
});
}
}