Monkey中出现了一个ANR
dumpsys window中
mCurrentFocus=Window{2fd4f04 u0 com.google.android.inputmethod.latin}
mFocusedApp=ActivityRecord{f2c78bf u0 com.android.settings/.Settings$RunningServicesActivity t7015}
但是dumpsys SurfaceFlinger中没有对应的Layer。
后面找到了一个复现路径:应用进行输入,弹出输入法键盘,再进入输入法设置弹框, 依赖的提示框挂掉,此时再输入input key事件,会出现ANR
问题原因分析大概如下:
Window存在而Layer不存在的原因: dumpsys window中看到输入法浮窗和输入法主窗口之间是子父关系,在SurfaceFlinger端的Layer也同样是子父关系,当父窗口隐藏,子窗口在SF端的Layer也会消失;
本来,在Android 系统里面,父窗口隐藏,其相应的子窗口也会隐藏,windowstate代码逻辑如下:
boolean wouldBeVisibleIfPolicyIgnored(){
return mHasSurface && !isParentWindowHidden() && !mAnimatingExit && !mDestroying && (!mIsWallpaper || mWallpaperVisible);
}
但是,这个case里面,父窗口隐藏了,但是子窗口windowstate状态依然是show,其原因是:
父窗口的隐藏路径