在我的测试中,我在 ActivityManagerService 的 updateOomAdjLocked() 中看到以下异常:
// java.lang.IndexOutOfBoundsException: Invalid index 27, size is 27
// at java.util.ArrayList.throwIndexOutOfBoundsException(ArrayList.java:251)
// at java.util.ArrayList.get(ArrayList.java:304)
// at com.android.server.am.ActivityManagerService.updateOomAdjLocked(ActivityManagerService.java:13880)
// at com.android.server.am.ActivityManagerService.updateLruProcessLocked(ActivityManagerService.java:1904)
// at com.android.server.am.ActivityStack.realStartActivityLocked(ActivityStack.java:647)
// at com.android.server.am.ActivityStack.startSpecificActivityLocked(ActivityStack.java:803)
有问题的代码似乎如下(Android 4.2.2 r1.2 的第 13850 行):
final ArrayList<ProcessRecord> mLruProcesses
= new ArrayList<ProcessRecord>();
{...}
final void updateOomAdjLocked() {
{...}
final int N = mLruProcesses.size();
for (i=0; i<N; i++) {
ProcessRecord app = mLruProcesses.get(i);
{...}
}
如果在循环中调用 mLruProcesses.remove,则 mLruProcesses.get(i) for i=N 访问不存在的索引,从而触发异常。
到目前为止,我对 Android 服务知之甚少,所以我的问题是这段代码是否需要可重新输入,也许是通过使某些操作线程安全?