2017-02-25 20 views
0

バックグラウンドスレッドで、進行状況の値を更新するバックグラウンドスレッドを持つフラグメントがあります。同じ活動のそれの場合には、このエラーフラグメントが破棄されたときにバックグラウンドスレッドを終了する

E/UncaughtException: java.lang.NullPointerException: Attempt to invoke virtual method 'android.content.res.Resources android.support.v4.app.FragmentActivity.getResources()' on a null object reference 
    at com.example.mego.adas.ui.CarFragment$PotProgressThread$1.run(CarFragment.java:831) 
    at android.os.Handler.handleCallback(Handler.java:739) 
    at android.os.Handler.dispatchMessage(Handler.java:95) 
    at android.os.Looper.loop(Looper.java:148) 
    at android.app.ActivityThread.main(ActivityThread.java:7409) 
    at java.lang.reflect.Method.invoke(Native Method) 
    at com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:1230) 
E/AndroidRuntime: FATAL EXCEPTION: main Process: com.example.mego.adas, PID: 25935 
java.lang.NullPointerException: Attempt to invoke virtual method 'android.content.res.Resources android.support.v4.app.FragmentActivity.getResources()' on a null object reference 
    at com.example.mego.adas.ui.CarFragment$PotProgressThread$1.run(CarFragment.java:831) 
    at android.os.Handler.handleCallback(Handler.java:739) 
    at android.os.Handler.dispatchMessage(Handler.java:95) 
    at android.os.Looper.loop(Looper.java:148) 
    at android.app.ActivityThread.main(ActivityThread.java:7409) 
    at java.lang.reflect.Method.invoke(Native Method) 
    at com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:1230) 
    at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:1120) 

は、ここで私は(onCreateViewの私のスレッドを開始キャストスレッドここ

class PotProgressThread implements Runnable { 

    @Override 
    public void run() { 
     while (potSensorValue <= 1025 && fragmentIsRunning) { 

      if (fragmentIsRunning) { 

       // Update the progress bar 
       potProgressBarHandler.post(new Runnable() { 
        public void run() { 
         potProgressBar.setProgress((int) potSensorValue); 
         if (potSensorValue >= 800) { 
          potProgressBar.setProgressDrawable(getActivity(). 
            getResources().getDrawable(R.drawable.progressbarred)); 
         } else { 
          potProgressBar.setProgressDrawable(getActivity(). 
            getResources().getDrawable(R.drawable.progressbarblue)); 

         } 
        } 
       }); 
       try { 
        Thread.sleep(50); 
       } catch (InterruptedException e) { 
        e.printStackTrace(); 
       } 
      } else { 
       break; 
      } 
     } 
    } 
} 

ためのコードがある)メソッド

ここでは
@Override 
public View onCreateView(LayoutInflater inflater, ViewGroup container, 
         Bundle savedInstanceState) { 


    View rootView = inflater.inflate(R.layout.fragment_car, container, false); 
    initializeScreen(rootView); 

    //check the internet connection 
    connectivityManager = (ConnectivityManager) getActivity().getSystemService(Context.CONNECTIVITY_SERVICE); 
    networkInfo = connectivityManager.getActiveNetworkInfo(); 

    if (networkInfo != null && networkInfo.isConnected()) { 
     buildGoogleApiClient(); 

     //set up the firebase 
     mFirebaseDatabase = FirebaseDatabase.getInstance(); 

     //get the references for the childes 
     //the main child for the directions services 
     carDatabaseReference = mFirebaseDatabase.getReference().child(constant.FIREBASE_CAR); 

     //the childes for the direction root 
     connectionStateDatabaseReference = mFirebaseDatabase.getReference() 
       .child(constant.FIREBASE_CAR).child(constant.FIREBASE_CONNECTION_STATE); 

     accidentStateDatabaseReference = mFirebaseDatabase.getReference() 
       .child(constant.FIREBASE_CAR).child(constant.FIREBASE_ACCIDENT_STATE); 

     startStateStateDatabaseReference = mFirebaseDatabase.getReference() 
       .child(constant.FIREBASE_CAR).child(constant.FIREBASE_START_STATE); 

     lightsStateDatabaseReference = mFirebaseDatabase.getReference() 
       .child(constant.FIREBASE_CAR).child(constant.FIREBASE_LIGHTS_STATE); 

     lockStateDatabaseReference = mFirebaseDatabase.getReference() 
       .child(constant.FIREBASE_CAR).child(constant.FIREBASE_LOCK_STATE); 

     mappingServicesDatabaseReference = mFirebaseDatabase.getReference() 
       .child(constant.FIREBASE_CAR).child(constant.FIREBASE_MAPPING_SERVICES); 

     sensorsValuesDatabaseReference = mFirebaseDatabase.getReference() 
       .child(constant.FIREBASE_CAR).child(constant.FIREBASE_SENSORES_VALUES); 

     connectionStateDatabaseReference.setValue(1); 


    } 
    //show Snackbar if there is no internet net connection 
    else { 
     if (carFragment != null) { 

      // Snackbar snackbar = Snackbar.make(carFragment, R.string.no_internet_connection, Snackbar.LENGTH_LONG); 
      // snackbar.show(); 
     } 
    } 

    //get the date from the connected thread 
    bluetoothHandler = new Handler() { 
     public void handleMessage(android.os.Message msg) { 
      //if message is what we want 
      if (msg.what == handlerState) { 
       // msg.arg1 = bytes from connect thread 
       String readMessage = (String) msg.obj; 

       //keep appending to string until ~ char 
       recDataString.append(readMessage); 

       //determine the end of the line 
       endOfLineIndex = recDataString.indexOf("~"); 
       if (fragmentIsRunning) { 
        refreshUI(); 
       } 

      } 
     } 
    }; 

    //setup ans start the threads 
    potThread = new Thread(new PotProgressThread()); 
    tempThread = new Thread(new TemperatureProgressThread()); 
    ldrThread = new Thread(new LdrProgressThread()); 


    fragmentIsRunning = true; 
    potThread.start(); 
    tempThread.start(); 
    ldrThread.start(); 


    //set the buttons listener 
    lightsButton.setOnClickListener(this); 
    lockButton.setOnClickListener(this); 
    disconnectButton.setOnClickListener(this); 
    startButton.setOnClickListener(this); 

    //setup the map fragment 
    MapFragment mapFragment = (MapFragment) getActivity().getFragmentManager().findFragmentById(R.id.my_location_fragment_car); 
    mapFragment.getMapAsync(this); 

    // Inflate the layout for this fragment 
    return rootView; 
} 

それが終了または完了されていない限り、あなたのスレッドが実行し続けますので、onDestoryview()メソッドのコード

fragmentIsRunning = false; 
potThread.interrupt(); 

どのように私はそれを殺すことができる

+0

あなたのonCreateView()メソッドコードを共有してください。 – Shailesh

+0

ok私は –

+0

の質問を編集します。 –

答えて

0

のDalvikランタイム内のすべてのスレッドの参照を保持しています(一部はreference)。したがって、スレッドをどこで開始するかによって、複数のスレッドを作成している可能性があります。

スレッド実行が完了せず、フラグメントを変更してgetActivity()がnullになるようにします。

ソリューションはgetActivity()の前にある、isAdded()をチェックすることは事実であるかどうか、真実でないならば、それは断片がすでに取り外されていることを意味、getActivity()に呼び出してnullを返します。

getActivity()に電話する前に、どこでもスレッドを覚えておいてください。スレッドが実行されている間はいつでもユーザーがアクティビティを終了できるので、isAdded()を再度チェックすることをお勧めします。

その他のソリューション

私はわからないが、あなたはあなたのスレッドでそのコンテキストをグローバルContextを初期化し、あなたによって達成することができます。

Context mContext; 

@Override 
public View onCreateView(LayoutInflater inflater, ViewGroup container, 
         Bundle savedInstanceState) 
{ 
    mContext = getActivity(); 
    .... 
} 

ここでスレッド内でこのコンテキストを使用してください。

class PotProgressThread implements Runnable { 

    @Override 
    public void run() { 
     while (potSensorValue <= 1025 && fragmentIsRunning) { 

      if (fragmentIsRunning) { 

       // Update the progress bar 
       potProgressBarHandler.post(new Runnable() { 
        public void run() { 
         potProgressBar.setProgress((int) potSensorValue); 
         if (potSensorValue >= 800) { 
          potProgressBar.setProgressDrawable(mContext. 
            getResources().getDrawable(R.drawable.progressbarred)); 
         } else { 
          potProgressBar.setProgressDrawable(mContext. 
            getResources().getDrawable(R.drawable.progressbarblue)); 

         } 
        } 
       }); 
       try { 
        Thread.sleep(50); 
       } catch (InterruptedException e) { 
        e.printStackTrace(); 
       } 
      } else { 
       break; 
      } 
     } 
    } 
} 

私はあなたが解決策を得ることを望みます。

+0

これは非常に非常に非常にありがとう、最初のsoluationは私の仕事です。二番目のしかし、私はそれが動作しないと思うので、私はこの断片を開始するときに私は他の断片に行くときにエラーが発生します –

関連する問題