gpt4 book ai didi

android - 为什么在 Activity 中调用 finish() 后不调用 onDestroy inActivity

转载 作者:塔克拉玛干 更新时间:2023-11-02 21:37:55 25 4
gpt4 key购买 nike

下一个过程很容易理解和重现,但会导致错误:

  • activityA 在其 onCreate() 方法中启动一个 activityB
  • activityB 已创建,我在其 onResume() 方法中调用 finish()
  • activityB onDestroy() 被调用
  • activityA onResume() 被调用
  • 在 ActivityA 中,我单击菜单按钮调用 finish() - 或按返回键。
  • activityA 已删除,但未调用 onDestroy() 并且 A 仍然存在(adb shell dumpsys 'myPackageName' 表示存在太多 Activity )

代码

<?xml version="1.0" encoding="utf-8"?>
<manifest xmlns:android="http://schemas.android.com/apk/res/android"
package="gleroy.com.algo">

<application
android:allowBackup="true"
android:icon="@mipmap/ic_launcher"
android:label="@string/app_name"
android:theme="@style/AppTheme">
<activity
android:name=".activity.MainActivity"
android:label="@string/app_name">
<intent-filter>
<action android:name="android.intent.action.MAIN" />

<category android:name="android.intent.category.LAUNCHER" />
</intent-filter>
</activity>


<activity
android:name="gleroy.com.algo.activity.FakeA"
android:label="@string/app_name"></activity>

<activity
android:name="gleroy.com.algo.activity.FakeB"
android:label="@string/app_name"></activity>
</application>
</manifest>

Activity A:

public class FakeA extends Activity {

private final static String TAG = FakeA.class.getCanonicalName();

@Override
protected void onCreate(Bundle savedInstanceState) {
Log.d(TAG, "onCreate, taskId :" + getTaskId());
super.onCreate(savedInstanceState);

Intent intent = new Intent(FakeA.this, FakeB.class);
startActivity(intent);
}

@Override
protected void onResume() {
Log.d(TAG, "onResume");
super.onResume();
}


@Override
protected void onDestroy() {
Log.d(TAG, "onDestroy");
super.onDestroy();
}

@TargetApi(Build.VERSION_CODES.HONEYCOMB)
@Override
public boolean onCreateOptionsMenu(Menu menu) {
// Inflate the menu; this adds items to the action bar if it is present.
getMenuInflater().inflate(R.menu.menu_main, menu);
super.onCreateOptionsMenu(menu);
return true;
}

@Override
public boolean onOptionsItemSelected(MenuItem item) {

switch (item.getItemId()) {
case R.id.stop_session_menu_item:
/* stop and quit */
finish();
return false;
}

return super.onOptionsItemSelected(item);
}
}

Activity B:

public class FakeB extends Activity {

private final static String TAG = FakeB.class.getCanonicalName();

@Override
protected void onCreate(Bundle savedInstanceState) {
Log.d(TAG, "onCreate, taskId :"+getTaskId());
super.onCreate(savedInstanceState);
}

@Override
protected void onResume() {
super.onResume();
Log.d(TAG, "onResume, isFinishing :" + isFinishing());
finish();
}

@Override
protected void onDestroy() {
super.onDestroy();
Log.d(TAG, "onDestroy");
}
}

Activity A 从包含一个简单按钮的 MainActivity 开始:

 @Override
protected void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
setContentView(R.layout.activity_main);

findViewById(R.id.btn).setOnClickListener(new View.OnClickListener() {
@Override
public void onClick(View v) {
Intent intent = new Intent(MainActivity.this, FakeA.class);
startActivity(intent);
}
});

所以我知道我们不能确定 onDestroy() 是否会被调用,但我的 ActivityA 显然正在泄漏。

我还观察到,如果我使用 TimerTimerTask 来延迟 ActivityA 或 finish() 中的 startActivity > 在 ActivityB 中,我就没有这个错误了。

事件如下:

  • FakeA onCreate, taskId :154
  • FakeA onResume
  • FakeA onPause, isFinishing : false
  • FakeB onCreate, taskId :154
  • FakeB onResume, isFinishing :false
  • FakeA onResume
  • FakeB onDestroy
  • call finish 或 press back key : FakeA onPause, isFinishing : true

最佳答案

代替 finish() 试试 finishAffinity()。我所知道的:finish() 只是销毁当前的 Activity ActivityfinishAffinity() 会销毁所有 Activity 的 Activities

关于android - 为什么在 Activity 中调用 finish() 后不调用 onDestroy inActivity,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/29941929/

25 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com