超出activity生命周期的Thread

本文介绍了一种在Android应用中使用Service来管理后台线程的方法。这种方法可以在Activity的生命周期结束时继续运行线程,避免了因Activity销毁而导致线程意外终止的问题。通过将线程置于Service中执行,即使Activity被销毁,线程也能继续运行,直到通过重新绑定Service并调用相应方法来停止它。

当开启的Thread的生命周期的要求很可能大于开启他的activity时,可以通过service解决问题。

在activity内部开启service,在service中开启线程,之后activity可以安安心心的go die,当需要关闭线程时,在任意activity中绑定之前的那个service,然后关闭线程。

这里面最关键的知识点是service可被任意activity绑定,并且service的实例是唯一的,不管绑定多少个activity,activity们操作的都是同一个service。

使用雅可比椭圆函数为Reissner平面有限应变梁提供封闭形式解(Matlab代码实现)内容概要:本文介绍了如何使用雅可比椭圆函数为Reissner平面有限应变梁问题提供封闭形式的解析解,并结合Matlab代码实现该求解过程。该方法能够精确描述梁在大变形条件下的非线性力学行为,适用于几何非线性强、传统线性理论失效的工程场景。文中详细阐述了数学建模过程,包括基本假设、控制方程推导以及利用雅可比椭圆函数进行积分求解的技术路线,最后通过Matlab编程验证了解的准确性与有效性。; 适合人群:具备一定固体力学、非线性结构分析基础,熟悉Matlab编程的研究生、博士生及科研人员,尤其适合从事结构力学、航空航天、土木工程等领域中大变形问题研究的专业人士; 使用场景及目标:① 掌握Reissner梁理论在有限应变条件下的数学建模方法;② 学习雅可比椭圆函数在非线性微分方程求解中的实际应用技巧;③ 借助Matlab实现复杂力学问题的符号计算与数值验证,提升理论与仿真结合能力; 阅读建议:建议读者在学习前复习弹性力学与非线性梁理论基础知识,重点关注控制方程的推导逻辑与边界条件的处理方式,同时动手运行并调试所提供的Matlab代码,深入理解椭圆函数库的调用方法与结果可视化流程,以达到理论与实践深度融合的目的。
11-23 18:08:42.224 1995 4914 E AndroidRuntime: *** FATAL EXCEPTION IN SYSTEM PROCESS: AppDeath #1 11-23 18:08:42.224 1995 4914 E AndroidRuntime: android.view.Surface$OutOfResourcesException: NO_MEMORY 11-23 18:08:42.224 1995 4914 E AndroidRuntime: at android.view.SurfaceControl.nativeCreate(Native Method) 11-23 18:08:42.224 1995 4914 E AndroidRuntime: at android.view.SurfaceControl.<init>(SurfaceControl.java:1665) 11-23 18:08:42.224 1995 4914 E AndroidRuntime: at android.view.SurfaceControl.<init>(Unknown Source:0) 11-23 18:08:42.224 1995 4914 E AndroidRuntime: at android.view.SurfaceControl$Builder.build(SurfaceControl.java:1321) 11-23 18:08:42.224 1995 4914 E AndroidRuntime: at com.android.server.wm.WindowContainer.setInitialSurfaceControlProperties(WindowContainer.java:804) 11-23 18:08:42.224 1995 4914 E AndroidRuntime: at com.android.server.wm.Task.setInitialSurfaceControlProperties(Task.java:3420) 11-23 18:08:42.224 1995 4914 E AndroidRuntime: at com.android.server.wm.WindowContainer.migrateToNewSurfaceControl(WindowContainer.java:840) 11-23 18:08:42.224 1995 4914 E AndroidRuntime: at com.android.server.wm.Task.migrateToNewSurfaceControl(Task.java:2607) 11-23 18:08:42.224 1995 4914 E AndroidRuntime: at com.android.server.wm.TaskOrganizerController$TaskOrganizerState.removeTask(TaskOrganizerController.java:481) 11-23 18:08:42.224 1995 4914 E AndroidRuntime: at com.android.server.wm.TaskOrganizerController$TaskOrganizerState.-$$Nest$mremoveTask(Unknown Source:0) 11-23 18:08:42.224 1995 4914 E AndroidRuntime: at com.android.server.wm.TaskOrganizerController.onTaskVanished(TaskOrganizerController.java:1048) 11-23 18:08:42.224 1995 4914 E AndroidRuntime: at com.android.server.wm.Task.sendTaskVanished(Task.java:4944) 11-23 18:08:42.224 1995 4914 E AndroidRuntime: at com.android.server.wm.Task.setTaskOrganizer(Task.java:4964) 11-23 18:08:42.224 1995 4914 E AndroidRuntime: at com.android.server.wm.Task.setTaskOrganizer(Task.java:4950) 11-23 18:08:42.224 1995 4914 E AndroidRuntime: at com.android.server.wm.Task.removeImmediately(Task.java:3105) 11-23 18:08:42.224 1995 4914 E AndroidRuntime: at com.android.server.wm.Task.removeIfPossible(Task.java:826) 11-23 18:08:42.224 1995 4914 E AndroidRuntime: at com.android.server.wm.Task.removeChild(Task.java:1730) 11-23 18:08:42.224 1995 4914 E AndroidRuntime: at com.android.server.wm.Task.removeChild(Task.java:1666) 11-23 18:08:42.224 1995 4914 E AndroidRuntime: at com.android.server.wm.WindowContainer.removeImmediately(WindowContainer.java:1052) 11-23 18:08:42.224 1995 4914 E AndroidRuntime: at com.android.server.wm.WindowToken.removeImmediately(WindowToken.java:362) 11-23 18:08:42.224 1995 4914 E AndroidRuntime: at com.android.server.wm.ActivityRecord.removeImmediately(ActivityRecord.java:5348) 11-23 18:08:42.224 1995 4914 E AndroidRuntime: at com.android.server.wm.WindowToken.removeIfPossible(WindowToken.java:267) 11-23 18:08:42.224 1995 4914 E AndroidRuntime: at com.android.server.wm.ActivityRecord.onRemovedFromDisplay(ActivityRecord.java:5411) 11-23 18:08:42.224 1995 4914 E AndroidRuntime: at com.android.server.wm.DisplayContent.removeAppToken(DisplayContent.java:1737) 11-23 18:08:42.224 1995 4914 E AndroidRuntime: at com.android.server.wm.ActivityRecord.removeFromHistory(ActivityRecord.java:4966) 11-23 18:08:42.224 1995 4914 E AndroidRuntime: at com.android.server.wm.ActivityRecord.handleAppDied(ActivityRecord.java:5325) 11-23 18:08:42.224 1995 4914 E AndroidRuntime: at com.android.server.wm.WindowProcessController.handleAppDied(WindowProcessController.java:1709) 11-23 18:08:42.224 1995 4914 E AndroidRuntime: at com.android.server.wm.ActivityTaskManagerService$LocalService.handleAppDied(ActivityTaskManagerService.java:7504) 11-23 18:08:42.224 1995 4914 E AndroidRuntime: at com.android.server.am.ActivityManagerService.handleAppDiedLocked(ActivityManagerService.java:3723) 11-23 18:08:42.224 1995 4914 E AndroidRuntime: at com.android.server.am.ActivityManagerService.appDiedLocked(ActivityManagerService.java:3909) 11-23 18:08:42.224 1995 4914 E AndroidRuntime: at com.android.server.am.ActivityManagerServiceExtImpl$2.run(ActivityManagerServiceExtImpl.java:2466) 11-23 18:08:42.224 1995 4914 E AndroidRuntime: at java.util.concurrent.ThreadPoolExecutor.runWorker(ThreadPoolExecutor.java:1156) 11-23 18:08:42.224 1995 4914 E AndroidRuntime: at java.util.concurrent.ThreadPoolExecutor$Worker.run(ThreadPoolExecutor.java:651) 11-23 18:08:42.224 1995 4914 E AndroidRuntime: at com.android.server.DeathRecipientTaskExecutors$1.lambda$newThread$0(DeathRecipientTaskExecutors.java:51) 11-23 18:08:42.224 1995 4914 E AndroidRuntime: at com.android.server.DeathRecipientTaskExecutors$1$$ExternalSyntheticLambda0.run(D8$$SyntheticClass:0) 11-23 18:08:42.224 1995 4914 E AndroidRuntime: at java.lang.Thread.run(Thread.java:1119) 安卓上层JE重启,这堆栈分析得出什么
11-25
评论
成就一亿技术人!
拼手气红包6.0元
还能输入1000个字符
 
红包 添加红包
表情包 插入表情
 条评论被折叠 查看
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值