Как убить поток в Android Studio - PullRequest
0 голосов
/ 16 февраля 2020

Цель: я хочу увеличить счетчик, когда приложение находится в фоновом режиме, а когда приложение возобновляет работу, его приращение должно прекратиться, тогда последнее значение счетчика будет отображаться на экране.

Фактически: но когда я запускаю свой код, счетчик успешно увеличивается, если приложение работает в фоновом режиме. Но когда я возобновляю, счетчик все еще увеличивается. Как я могу остановить эту тему, если она сейчас в резюме?

Это мой код в MainActivity. java

package com.example.background;

import androidx.appcompat.app.AppCompatActivity;

import android.os.Bundle;
import android.view.View;            
import android.widget.Button;            
import android.widget.TextView;

public class MainActivity extends AppCompatActivity {

TextView timeTextView;
Button buttonCtr;
int counter=0;
boolean isResume;
@Override
protected void onCreate(Bundle savedInstanceState) {

    super.onCreate(savedInstanceState);
    setContentView(R.layout.activity_main);

    timeTextView = (TextView) findViewById(R.id.timeLbl);
    buttonCtr = (Button) findViewById(R.id.ctrUp);

    buttonCtr.setOnClickListener(new View.OnClickListener() {
        @Override
        public void onClick(View view) {
            counter++;
            timeTextView.setText(String.valueOf(counter));
        }
    });


}

class backgroundProcess extends Thread {

    @Override
    public void run() {

        while(isResume == false ) {
            counter++;
            System.out.println(counter);
        }

        System.out.println("LAST COUNT:" + counter);

    }
}

@Override
protected void onPause() {
    super.onPause();
    isResume=false;
    System.out.println("IM IN PAUSE");
    System.out.println("IS RESUME: "+ isResume);
    new Thread(new backgroundProcess()).start();
}

@Override
protected void onRestart() {
    super.onRestart();

    isResume=true; //to stop backgroundProcess Thread

    System.out.println("IM IN RESUME");
    System.out.println("IS RESUME: "+ isResume);
    System.out.println("LAST COUNT:"+ counter);
    timeTextView.setText(String.valueOf(counter));

}

}

и это мой код для моего xml файла

<?xml version="1.0" encoding="utf-8"?>
<androidx.constraintlayout.widget.ConstraintLayout 
xmlns:android="http://schemas.android.com/apk/res/android"
xmlns:app="http://schemas.android.com/apk/res-auto"
xmlns:tools="http://schemas.android.com/tools"
android:layout_width="match_parent"
android:layout_height="match_parent"
tools:context=".MainActivity">

<TextView
    android:id="@+id/timeLbl"
    android:layout_width="wrap_content"
    android:layout_height="wrap_content"
    android:text="0"
    android:textSize="18sp"
    app:layout_constraintBottom_toBottomOf="parent"
    app:layout_constraintHorizontal_bias="0.482"
    app:layout_constraintLeft_toLeftOf="parent"
    app:layout_constraintRight_toRightOf="parent"
    app:layout_constraintTop_toTopOf="parent"
    app:layout_constraintVertical_bias="0.397" />

<Button
    android:id="@+id/ctrUp"
    android:layout_width="wrap_content"
    android:layout_height="wrap_content"
    android:layout_marginBottom="196dp"
    android:text="Button"
    app:layout_constraintBottom_toBottomOf="parent"
    app:layout_constraintEnd_toEndOf="parent"
    app:layout_constraintHorizontal_bias="0.475"
    app:layout_constraintStart_toStartOf="parent"
    app:layout_constraintTop_toBottomOf="@+id/timeLbl"
    app:layout_constraintVertical_bias="0.54" />

</androidx.constraintlayout.widget.ConstraintLayout>

1 Ответ

0 голосов
/ 16 февраля 2020

2 вещи, здесь:

  1. Вы не используете какие-либо примитивы синхронизации. Это означает, что чтение фоновым потоком isResume ненадежно; фоновому потоку может показаться, что isResume равно false, хотя поток пользовательского интерфейса уже установил его на true. В этом конкретном случае вы сможете объявить isResume как volatile, и это устранит проблему когерентности кэша .

  2. Вы сбрасываете информацию logcat с чрезвычайно высокой скоростью, возможно, сотнями тысяч строк в секунду (System.out.println(counter)). Android Студия испытывает проблемы с чтением и отображением информации logcat с такой скоростью. В этом случае он обычно будет отставать, что может привести к тому, что ваш поток будет запущен, даже если он уже остановлен.

Я также должен упомянуть, что ваш доступ к counter не является потокобезопасным. В отличие от isResume, вы выполняете операции чтения / записи (++) на counter из обоих потоков, поэтому ключевое слово volatile является недостаточным исправлением. Вы должны убедиться, что все обращения к counter защищены фактической блокировкой (например, заключив их в блок synchronized(MainActivity.this)).

Добро пожаловать на сайт PullRequest, где вы можете задавать вопросы и получать ответы от других членов сообщества.
...