从setOnChronometerTickListener()重置时,计时码表崩溃

时间:2019-05-02 13:02:21

标签: java android chronometer

我正在尝试在计时器到达特定时间(在这种情况下为5秒)时使用setOnChronometerTickListener()重设计时器。但是,当我在手机上运行它时,它会崩溃。我正在使用this quesion的解决方案来重置计时器。

我尝试将天文钟重置为其他值,但仍然在chronometer.setBase(SystemClock.elapsedRealtime());崩溃

这是我的实现方式:

chrono.setOnChronometerTickListener(new Chronometer.OnChronometerTickListener() {
      @Override
      public void onChronometerTick(Chronometer chronometer) {
              if(chronometer.getText().toString().equalsIgnoreCase("00:05")) {
                        // Reset Chronometer
                        chronometer.stop();
                        chronometer.setBase(SystemClock.elapsedRealtime());


              }
      }
});

这是我从Logcat得到的错误消息:

2019-05-02 14:47:39.469 13143-13143/com.example.pomodoro_2 E/AndroidRuntime: FATAL EXCEPTION: main
    Process: com.example.pomodoro_2, PID: 13143
    java.lang.StackOverflowError: stack size 8MB
        at android.widget.Chronometer.updateRunning(Chronometer.java:321)
        at android.widget.Chronometer.stop(Chronometer.java:252)
        at com.example.pomodoro_2.MainActivity$3.onChronometerTick(MainActivity.java:88)
        at android.widget.Chronometer.dispatchChronometerTick(Chronometer.java:347)
        at android.widget.Chronometer.setBase(Chronometer.java:176)

我从此错误消息中假定我正在堆栈溢出,但我无法弄清楚原因,也没有看到类似的错误。预先感谢。

1 个答案:

答案 0 :(得分:1)

如果将日志放入if条件中,则会在00:05之后在logcat中看到该日志。 我通过从计时器中删除监听器来防止这种情况。

chrono.setOnChronometerTickListener(new Chronometer.OnChronometerTickListener() {
      @Override
      public void onChronometerTick(Chronometer chronometer) {
              if(chronometer.getText().toString().equalsIgnoreCase("00:05")) {
                        // Reset Chronometer
                        chronometer.setOnChronometerTickListener(null);
                        chronometer.stop();
                        chronometer.setBase(SystemClock.elapsedRealtime());


              }
      }
});

但是如果您需要此侦听器,则可以从 Chronometer.OnChronometerTickListener 实现片段,并实现OnChronometerTickListener,如下所示:

  public class MainActivity extends AppCompatActivity implements Chronometer.OnChronometerTickListener {

    private String TAG = "MainActivity";
    Button start;
    Chronometer chronometer;

    @Override
    protected void onCreate(Bundle savedInstanceState) {
        super.onCreate(savedInstanceState);
        setContentView(R.layout.activity_main);
        chronometer = findViewById(R.id.chron);
        start = findViewById(R.id.btn);
        start.setOnClickListener(new View.OnClickListener() {
            @Override
            public void onClick(View v) {
                chronometer.start();
            }
        });
        chronometer.start();
        chronometer.setOnChronometerTickListener(this);

    }

    @Override
    public void onChronometerTick(Chronometer chronometer) {
        if (chronometer.getText().toString().equalsIgnoreCase("00:05")) {
            // Reset Chronometer
            chronometer.setOnChronometerTickListener(null);
            chronometer.stop();
            Log.d(TAG, "onChronometerTick: stop");

            chronometer.setBase(SystemClock.elapsedRealtime());
            chronometer.setOnChronometerTickListener(this);


        }

    }
}