what happens when you call Activity#finish()

App:
android.app.Activity#finish(int)

android.app.ActivityClient#finishActivity()

ipc to  ams:
com.android.server.wm.ActivityClientController#finishActivity()

com.android.server.wm.ActivityRecord#finishIfPossible()

When DestroyActivityItem#obtain is called:

在这里插入图片描述

com.android.server.wm.ActivityTaskSupervisor#processStoppingAndFinishingActivities():   first  stop  then  finish  

com.android.server.wm.ActivityRecord#destroyIfPossible()

com.android.server.wm.ActivityRecord#destroyImmediately()

calls:   
        mAtmService.getLifecycleManager().scheduleTransaction(app.getThread(), token,
                        DestroyActivityItem.obtain(finishing, configChangeFlags));


When Activity#onDestory() is called:

server side :
com.android.server.wm.ActivityRecord#destroyImmediatel() calll this :

 mAtmService.getLifecycleManager().scheduleTransaction(app.getThread(), token,
                        DestroyActivityItem.obtain(finishing, configChangeFlags));

then goto client side:

java.lang.RuntimeException: Unable to destroy activity 
    	at android.app.ActivityThread.performDestroyActivity(ActivityThread.java:5424)
    	at android.app.ActivityThread.handleDestroyActivity(ActivityThread.java:5457)
    	at android.app.servertransaction.DestroyActivityItem.execute(DestroyActivityItem.java:47)
    	at android.app.servertransaction.ActivityTransactionItem.execute(ActivityTransactionItem.java:45)
    	at android.app.servertransaction.TransactionExecutor.executeLifecycleState(TransactionExecutor.java:179)
    	at android.app.servertransaction.TransactionExecutor.execute(TransactionExecutor.java:97)
    	at android.app.ActivityThread$H.handleMessage(ActivityThread.java:2306)
    	at android.os.Handler.dispatchMessage(Handler.java:106)
    	at android.os.Looper.loopOnce(Looper.java:201)
    	at android.os.Looper.loop(Looper.java:288)
    	at android.app.ActivityThread.main(ActivityThread.java:7918)
    	at java.lang.reflect.Method.invoke(Native Method)
    	at com.android.internal.os.RuntimeInit$MethodAndArgsCaller.run(RuntimeInit.java:548)
    	at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:936)

because ActivityThread get a DestroyActivityItem from ams.

Who calls ActivityRecord#destroyImmediatel() ?:

com.android.server.wm.ActivityRecord#destroyIfPossible()
com.android.server.wm.ActivityTaskSupervisor#processStoppingAndFinishingActivities()

在这里插入图片描述

When com.android.server.wm.ActivityClientController#activityIdle is called:

app side  is  android.app.ActivityClient#activityIdle()

What is a IdleHandler :

 Callback interface for discovering when a thread is going to block  waiting for more messages.

DESTRO TIMEOUT is 10s

// How long we wait until giving up on an activity telling us it has
// finished destroying itself.
private static final int DESTROY_TIMEOUT = 10 * 1000;

To do:

  • 4
    点赞
  • 3
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值