2017-11-29 9 views
5

SpaneableStringInternalでNPEのCrashlyticsでエラーレポートを受け取っていますが、どの電話でも問題を再現できなかったり、ソースを特定できませんでした。私は根本的な問題を特定するのを助けるためにインターネットを求めています。android.widget.Editor:SpannableStringInternalのNullPointerException

Fatal Exception: java.lang.NullPointerException: Attempt to invoke virtual method 'int java.lang.Object.hashCode()' on a null object reference 
    at android.text.SpannableStringInternal.hashCode(SpannableStringInternal.java:480) 
    at android.text.SpannedString.hashCode(SpannedString.java) 
    at java.util.Objects.hashCode(Objects.java:98) 
    at android.view.inputmethod.CursorAnchorInfo.<init>(CursorAnchorInfo.java:435) 
    at android.view.inputmethod.CursorAnchorInfo.<init>(CursorAnchorInfo.java) 
    at android.view.inputmethod.CursorAnchorInfo$Builder.build(CursorAnchorInfo.java:391) 
    at android.widget.Editor$CursorAnchorInfoNotifier.updatePosition(Editor.java:4390) 
    at android.widget.Editor$PositionListener.onPreDraw(Editor.java:3250) 
    at android.view.ViewTreeObserver.dispatchOnPreDraw(ViewTreeObserver.java:1013) 
    at android.view.ViewRootImpl.performTraversals(ViewRootImpl.java:2492) 
    at android.view.ViewRootImpl.doTraversal(ViewRootImpl.java:1509) 
    at android.view.ViewRootImpl$TraversalRunnable.run(ViewRootImpl.java:7051) 
    at android.view.Choreographer$CallbackRecord.run(Choreographer.java:927) 
    at android.view.Choreographer.doCallbacks(Choreographer.java:702) 
    at android.view.Choreographer.doFrame(Choreographer.java:638) 
    at android.view.Choreographer$FrameDisplayEventReceiver.run(Choreographer.java:913) 
    at android.os.Handler.handleCallback(Handler.java:751) 
    at android.os.Handler.dispatchMessage(Handler.java:95) 
    at android.os.Looper.loop(Looper.java:154) 
    at android.app.ActivityThread.main(ActivityThread.java:6692) 
    at java.lang.reflect.Method.invoke(Method.java) 
    at com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:1468) 
    at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:1358) 

ソースから、何らかの形でカーソル/選択によってNULLスパンが設定されているように見えます。

エラーが唯一のAndroid 7に発生します。 同じ問題に直面してCrashlytics device info

+4

私は、いくつかのサンプルコードを提供していない場合、大きな助けにならないと思います。 – Al0x

+2

@ Al0x私はここにアプリケーションコード全体を掲載することができ、あなたと私の両方は賢明ではないでしょう。このアプリケーションには50種類以上の 'EditText'があり、動作が異なります。クラッシュがいつどこで起きているかわからないので、関連するコードを投稿できませんでした。 – Mannaz

+1

これは厳しいものです。 'CursorAnchorInfo'の' Build'で、スレッドセーフではないことが分かります。 ([こちら](https://github.com/aosp-mirror/platform_frameworks_base/blob/master/core/java/android/view/inputmethod/CursorAnchorInfo.java#L255)を参照してください)。スレッド間でスパンを操作していますか? – Cheticamp

答えて

0

。私のケースでは、リッチテキストパーサーのlib cwac-richeditの魔女が設定されていたのはで、nullをスパムに変換するのに対し、はhtmlをspannableに解析します。ここにはfixがあります。

EditTextに設定されているCharSequenceをどこから取得するかを確認します。nullスパンがどこかに設定されている可能性が非常に高いです。 私の場合、それらのスパンを設定したのはカーソルまたは選択肢ではありませんでした。

関連する問題