2017-01-17 7 views
0

У меня появилось несколько отчетов о сбоях в нашем приложении.Context.getResources() NPE

Эта ошибка была подана из интерфейса Socorro и находится в поле . Отчет bp-d1b4cdb8-fd3f-457b-9a29-df9192170112. Сокорро-Подпись:

java.lang.NullPointerException: Attempt to invoke virtual method ''android.content.res.Resources android.content.Context.getResources()'' on a null object reference: at dnu.afterTextChanged(CommentOperatingFragment.java)

Java трассировки стека:

java.lang.NullPointerException: Attempt to invoke virtual method 'android.content.res.Resources android.content.Context.getResources()' on a null object reference 
    at dnu.afterTextChanged(CommentOperatingFragment.java:252) 
    at android.widget.TextView.sendAfterTextChanged(TextView.java:7929) 
    at android.widget.TextView.setText(TextView.java:4084) 
    at android.widget.TextView.setText(TextView.java:3933) 
    at android.widget.EditText.setText(EditText.java:85) 
    at android.widget.TextView.setText(TextView.java:3908) 
    at dnv.a(CommentOperatingFragment.java:269) 
    at dpz.a(SoftKeyboardStateHelper.java:84) 
    at dpz.onGlobalLayout(SoftKeyboardStateHelper.java:47) 
    at android.view.ViewTreeObserver.dispatchOnGlobalLayout(ViewTreeObserver.java:912) 
    at android.view.ViewRootImpl.performTraversals(ViewRootImpl.java:1899) 
    at android.view.ViewRootImpl.doTraversal(ViewRootImpl.java:1079) 
    at android.view.ViewRootImpl$TraversalRunnable.run(ViewRootImpl.java:5915) 
    at android.view.Choreographer$CallbackRecord.run(Choreographer.java:773) 
    at android.view.Choreographer.doCallbacks(Choreographer.java:586) 
    at android.view.Choreographer.doFrame(Choreographer.java:556) 
    at android.view.Choreographer$FrameDisplayEventReceiver.run(Choreographer.java:759) 
    at android.os.Handler.handleCallback(Handler.java:739) 
    at android.os.Handler.dispatchMessage(Handler.java:95) 
    at android.os.Looper.loop(Looper.java:135) 

Вот мой код в CommentOperatingFragment:

@Override 
    public void onViewCreated(View view, @Nullable Bundle savedInstanceState) { 
     …... 
     mCommentEdt.addTextChangedListener(new TextWatcher() { 
      @Override 
      public void beforeTextChanged(CharSequence charSequence, 
              int i, int i1, int i2) { 
      } 

      @Override 
      public void onTextChanged(CharSequence charSequence, 
             int i, int i1, int i2) { 
      } 

      @Override 
      public void afterTextChanged(Editable editable) { 
       if (mCommentEdt.getText().toString().isEmpty()) { 
        mPostTxt.setClickable(false); 
        mPostTxt.setTextColor(ResourcesCompat.getColor(getContext().getResources(),// Line 252 
          R.color.article_comment_area_post_color_without_text, null)); 
       } else { 
        mPostTxt.setClickable(true); 
        mPostTxt.setTextColor(ResourcesCompat.getColor(getContext().getResources(), 
          R.color.article_comment_area_post_color_with_text, null)); 
       } 
      } 
     }); 
} 

Это произошло на нескольких устройствах.

6.0.1, SAMSUNG-SM-G935A 6.0.1, SAMSUNG-SM-G890A 6,0, Alco 6.0.1, Моторола, XT1585

Я не знаю, если это то же самое с https://code.google.com/p/android/issues/detail?id=56296

Я также задаюсь вопросом, связано ли это с местоположением getContext. Я назвал его в Fragment.onViewCreated.

Но это говорит в исходном коде: иерархия представлений фрагмента, однако, не привязана к ее родительскому объекту в данный момент.

+0

Почему не используется 'getActivity()'? –

+0

вы также можете использовать view.getcontext() –

+0

@ ρяσѕρєяK @ keyur9779 Спасибо, что высказали свои замечания. Не могли бы вы, ребята, указать здесь разницу между getActivity, getContext и view.getContext? –

ответ

1

Изменить

ResourcesCompat.getColor(getContext().getResources(), 
          R.color.article_comment_area_post_color_with_text, null) 

в

ContextCompat.getColor(getActivity(), R.color.article_comment_area_post_color_with_text) 
+0

Не могли бы вы объяснить, почему первый будет выдавать исключение? –

+0

Я читал до этого, иногда 'getContext()' возвращает NPE. Вы должны использовать 'getActivity()' вместо 'getContext()' во время разработки. – TruongHieu

+0

Вы помните, где вы это читали? Или вы могли бы дать мне некоторые материалы о том, что getContext() вернет NPE? Я никогда не знал, что такое произойдет. –