คำตอบและหมายเหตุต่างๆอ้างว่าเสร็จสิ้น () สามารถข้าม onPause () และ onStop () และดำเนินการโดยตรงบน onDestroy () เพื่อความเป็นธรรมเอกสาร Android เกี่ยวกับเรื่องนี้ ( http://developer.android.com/reference/android/app/Activity.html ) บันทึก "กิจกรรมกำลังสิ้นสุดลงหรือถูกทำลายโดยระบบ" ซึ่งค่อนข้างคลุมเครือ แต่อาจแนะนำว่า เสร็จสิ้น () สามารถข้ามไปยัง onDestroy ()
JavaDoc เมื่อเสร็จสิ้น () ค่อนข้างน่าผิดหวังในทำนองเดียวกัน ( http://developer.android.com/reference/android/app/Activity.html#finish () ) และไม่ได้สังเกตว่าวิธีการใดที่เรียกว่าเป็นการตอบสนองเมื่อเสร็จสิ้น ()
ดังนั้นฉันจึงเขียนมินิแอพด้านล่างซึ่งบันทึกแต่ละรัฐเมื่อเข้า มันมีปุ่มที่เรียกเสร็จ () - เพื่อให้คุณสามารถดูบันทึกของวิธีการที่ได้รับการยิง การทดลองนี้จะแนะนำให้เสร็จสิ้น ()จะเรียก onPause () และ onStop () ด้วย นี่คือผลลัพธ์ที่ฉันได้รับ:
2170-2170/? D/LIFECYCLE_DEMO﹕ INSIDE: onCreate
2170-2170/? D/LIFECYCLE_DEMO﹕ INSIDE: onStart
2170-2170/? D/LIFECYCLE_DEMO﹕ INSIDE: onResume
2170-2170/? D/LIFECYCLE_DEMO﹕ User just clicked button to initiate finish()
2170-2170/? D/LIFECYCLE_DEMO﹕ INSIDE: onPause
2170-2170/? D/LIFECYCLE_DEMO﹕ INSIDE: onStop
2170-2170/? D/LIFECYCLE_DEMO﹕ INSIDE: onDestroy
package com.mvvg.apps.lifecycle;
import android.app.Activity;
import android.os.Bundle;
import android.util.Log;
import android.view.View;
import android.view.View.OnClickListener;
import android.widget.Button;
import android.widget.LinearLayout;
import android.widget.Toast;
public class AndroidLifecycle extends Activity {
private static final String TAG = "LIFECYCLE_DEMO";
@Override
protected void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
Log.d(TAG, "INSIDE: onCreate");
setContentView(R.layout.activity_main);
LinearLayout layout = (LinearLayout) findViewById(R.id.myId);
Button button = new Button(this);
button.setOnClickListener(new OnClickListener() {
@Override
public void onClick(View view) {
Toast.makeText(AndroidLifecycle.this, "Initiating finish()",
Toast.LENGTH_SHORT).show();
Log.d(TAG, "User just clicked button to initiate finish()");
finish();
}
});
layout.addView(button);
}
@Override
protected void onStart() {
super.onStart();
Log.d(TAG, "INSIDE: onStart");
}
@Override
protected void onStop() {
super.onStop();
Log.d(TAG, "INSIDE: onStop");
}
@Override
protected void onDestroy() {
super.onDestroy();
Log.d(TAG, "INSIDE: onDestroy");
}
@Override
protected void onPause() {
super.onPause();
Log.d(TAG, "INSIDE: onPause");
}
@Override
protected void onResume() {
super.onResume();
Log.d(TAG, "INSIDE: onResume");
}
}