EditText:InputConnection.reportFullscreenMode 中的 NPE
EditText: NPE in InputConnection.reportFullscreenMode
注意:我试图解决的问题仅限于基于 Rockchip RK312X 的无名中国平板电脑 运行 SDK 23 (Marshmallow)。似乎没有其他设备受到影响,但不幸的是,我被迫使用那些蹩脚的设备(顺便说一句,它们上面也有串行端口)用于开发和演示目的。
问题:当包含 EditText
的任何子类的 any 布局从 window 中删除时(finish()
在 Activity,包含 EditText 的自定义 DialogFragment
被关闭等)应用程序崩溃,给出以下堆栈跟踪(完整输出):
java.lang.NullPointerException: Attempt to invoke interface method 'boolean android.view.inputmethod.InputConnection.reportFullscreenMode(boolean)' on a null object reference
at android.view.inputmethod.InputConnectionWrapper.reportFullscreenMode(InputConnectionWrapper.java:122)
at com.android.internal.view.IInputConnectionWrapper.executeMessage(IInputConnectionWrapper.java:416)
at com.android.internal.view.IInputConnectionWrapper$MyHandler.handleMessage(IInputConnectionWrapper.java:78)
at android.os.Handler.dispatchMessage(Handler.java:102)
at android.os.Looper.loop(Looper.java:148)
at android.app.ActivityThread.main(ActivityThread.java:5417)
at java.lang.reflect.Method.invoke(Native Method)
at com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:746)
at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:636)
这是一个非常简单的布局示例:
<android.support.design.widget.TextInputLayout
android:id="@+id/tilConnectionToken"
android:layout_width="match_parent"
android:layout_height="wrap_content"
android:layout_below="@+id/tvSetupInfo"
android:layout_marginEnd="15dp"
android:layout_marginStart="15dp"
android:layout_marginTop="10dp"
android:ems="10"
app:errorEnabled="true"
android:hint="@string/conn_token">
<android.support.design.widget.TextInputEditText
android:id="@+id/etConnectionToken"
android:maxLines="1"
android:inputType="text"
android:imeOptions="actionDone"
android:layout_width="match_parent"
android:layout_height="wrap_content" />
</android.support.design.widget.TextInputLayout>
Activity
并没有真正做任何事情:
class ConnectWizardActivity : AppCompatActivity(), View.OnClickListener {
override fun onCreate(savedInstanceState: Bundle?) {
super.onCreate(savedInstanceState)
setContentView(R.layout.activity_setup_wiz)
btnCancel.setOnClickListener(this)
}
override fun onClick(v: View) {
when (v.id) {
R.id.btnCancel -> finish()
}
}
}
调用 finish()
已经导致上面提供的堆栈跟踪崩溃。我在完成 Activity 之前尝试过的内容:
- 正在从
EditText
中清除焦点
- 隐藏软键盘
- 从容器中完全移除
EditText
(和其他 Views
)
相同的 NPE 不断发生。正如我之前所说,该问题并不局限于特定的 Activity 或 EditText 的特定子类 - 它在这些设备上无处不在。
我认为通常应该发生的事情:例如这个日志来自华为 MediaPad T3,没有崩溃
W/IInputConnectionWrapper: finishComposingText on inactive InputConnection
关于如何在无名 Marshmallow 设备上解决 NPE 的任何想法?
我遇到了同样的问题,最终发现 Android Studio 的 "Advance profiling" 功能是罪魁祸首。
解释了如何禁用该选项。希望这对您有所帮助!
注意:我试图解决的问题仅限于基于 Rockchip RK312X 的无名中国平板电脑 运行 SDK 23 (Marshmallow)。似乎没有其他设备受到影响,但不幸的是,我被迫使用那些蹩脚的设备(顺便说一句,它们上面也有串行端口)用于开发和演示目的。
问题:当包含 EditText
的任何子类的 any 布局从 window 中删除时(finish()
在 Activity,包含 EditText 的自定义 DialogFragment
被关闭等)应用程序崩溃,给出以下堆栈跟踪(完整输出):
java.lang.NullPointerException: Attempt to invoke interface method 'boolean android.view.inputmethod.InputConnection.reportFullscreenMode(boolean)' on a null object reference
at android.view.inputmethod.InputConnectionWrapper.reportFullscreenMode(InputConnectionWrapper.java:122)
at com.android.internal.view.IInputConnectionWrapper.executeMessage(IInputConnectionWrapper.java:416)
at com.android.internal.view.IInputConnectionWrapper$MyHandler.handleMessage(IInputConnectionWrapper.java:78)
at android.os.Handler.dispatchMessage(Handler.java:102)
at android.os.Looper.loop(Looper.java:148)
at android.app.ActivityThread.main(ActivityThread.java:5417)
at java.lang.reflect.Method.invoke(Native Method)
at com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:746)
at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:636)
这是一个非常简单的布局示例:
<android.support.design.widget.TextInputLayout
android:id="@+id/tilConnectionToken"
android:layout_width="match_parent"
android:layout_height="wrap_content"
android:layout_below="@+id/tvSetupInfo"
android:layout_marginEnd="15dp"
android:layout_marginStart="15dp"
android:layout_marginTop="10dp"
android:ems="10"
app:errorEnabled="true"
android:hint="@string/conn_token">
<android.support.design.widget.TextInputEditText
android:id="@+id/etConnectionToken"
android:maxLines="1"
android:inputType="text"
android:imeOptions="actionDone"
android:layout_width="match_parent"
android:layout_height="wrap_content" />
</android.support.design.widget.TextInputLayout>
Activity
并没有真正做任何事情:
class ConnectWizardActivity : AppCompatActivity(), View.OnClickListener {
override fun onCreate(savedInstanceState: Bundle?) {
super.onCreate(savedInstanceState)
setContentView(R.layout.activity_setup_wiz)
btnCancel.setOnClickListener(this)
}
override fun onClick(v: View) {
when (v.id) {
R.id.btnCancel -> finish()
}
}
}
调用 finish()
已经导致上面提供的堆栈跟踪崩溃。我在完成 Activity 之前尝试过的内容:
- 正在从
EditText
中清除焦点
- 隐藏软键盘
- 从容器中完全移除
EditText
(和其他Views
)
相同的 NPE 不断发生。正如我之前所说,该问题并不局限于特定的 Activity 或 EditText 的特定子类 - 它在这些设备上无处不在。
我认为通常应该发生的事情:例如这个日志来自华为 MediaPad T3,没有崩溃
W/IInputConnectionWrapper: finishComposingText on inactive InputConnection
关于如何在无名 Marshmallow 设备上解决 NPE 的任何想法?
我遇到了同样的问题,最终发现 Android Studio 的 "Advance profiling" 功能是罪魁祸首。