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 之前尝试过的内容:

相同的 NPE 不断发生。正如我之前所说,该问题并不局限于特定的 Activity 或 EditText 的特定子类 - 它在这些设备上无处不在。

我认为通常应该发生的事情:例如这个日志来自华为 MediaPad T3,没有崩溃

W/IInputConnectionWrapper: finishComposingText on inactive InputConnection

关于如何在无名 Marshmallow 设备上解决 NPE 的任何想法?

我遇到了同样的问题,最终发现 Android Studio 的 "Advance profiling" 功能是罪魁祸首。

解释了如何禁用该选项。希望这对您有所帮助!