windows phone因为墓碑化导致“正在恢复”的分析
我们在平时的WP使用过程中,会遇到一个问题
- 有时候,会显示“正在恢复”,并等待时间较长,才能回到用户切出时候的画面,但是这种情况并非常见,偶尔发生
- 有时候,直接回到切出时的画面,反应还蛮迅速的
这是为什么那?
我做了研究,分析如下:
首先,我们看一下WP的生命周期
(详情见:App activation and deactivation for Windows Phone 8)
当应用因为
- 用户点击WIN键
- 发送短信,跳往WIFI设置,或者其他Task
切出应用后,会触发事件Deactivated,失活,也就是不在前台显示了
然后,
这里是关键
存在两个状态
- Dormant
- TomeStoned
Dormant When the user navigates forward, away from an app, after the Deactivated event is raised,
the operating system will attempt to put the app into a dormant state.
In this state, all of the application’s threads are stopped and no processing takes place,
but the application remains intact in memory. If the app is reactivated from the dormant,
it doesn’t need to do anything to re-establish state, because it has been preserved. If new apps are launched after an app has been made dormant,
and these applications requires more memory than is available to provide a good user experience,
the operating system will begin to tombstone dormant applications to free up memory.
休眠
当用户向前导航或导航出应用时,引发 Deactivated 事件后,操作系统将尝试使应用置于休眠状态。在此状态下,应用程序的所有线程均将停止,并且不进行任何处理操作,但应用程序仍完好地保留在内存中。如果应用是从休眠状态重新激活的,则无需执行任何操作来重建状态,因为状态已被保留。
如果在应用进入休眠状态后启动新的应用,这些应用需要更多的内存才能提供出色的用户体验,操作系统将开始逻辑删除休眠的应用以释放内存。
Tombstoned A tombstoned app has been terminated, but the operating system preserves information about its navigation state
and also preserves the state dictionaries the app populated during Deactivated.
The device will maintain tombstoning information for up to five apps at a time.
If an app is tombstoned and the user navigates back to the application,
it will be relaunched and the application can use the preserved data to restore state.
已逻辑删除(即墓碑化)
已终止逻辑删除的应用,但操作系统不仅保留了有关其导航状态的信息,而且还保留了 Deactivated 期间填充应用的状态字典。设备每次最多可维护五个应用的逻辑删除信息。如果在逻辑删除应用之后,用户向后导航至应用程序,则应用程序将会重新启动并使用保留的数据还原状态。
回到问题
应用在切出,切回后,
- 有时候,会显示“正在恢复”,并等待时间较长,才能回到用户切出时候的画面,但是这种情况并非常见,偶尔发生
- 有时候,直接回到切出时的画面,反应还蛮迅速的
我认为,
这是因为两种不同的状态返回了应用而致:
应用是从休眠状态重新激活的,则无需执行任何操作来重建状态,因为状态已被保留。
于是这样发生了2
应用进入休眠状态后启动新的应用,这些应用需要更多的内存才能提供出色的用户体验,操作系统将开始逻辑删除休眠的应用以释放内存。(这也是为什么低RAM-512MB的机器更容易出现此问题,他更容易进入此流程)
用户进入逻辑删除(墓碑化)后,再返回应用。
于是这样发生了1
但是上面的关于“墓碑化”的描述文字真的是没有解释为什么会产生会导致性能损失,从而显示“正在恢复”并等待
只是指导了一下开发者,应该在墓碑化前后的Deactivated和Actived中保存和恢复一些状态,实在是不负责啊!
因此,我们现在深入墓碑化,会发现墓碑化后返回应用与休眠后返回应用存在不同
休眠后返回应用
墓碑化后返回(请留心Back之后的区别)
相信细心的你也已经看出来了:
从墓碑化状态Back回应用
居然如“开始屏幕”启动程序一样
重新走了一遍
App Constructor
Page Constructor
启动了一个新的app instance
虽然在“正在恢复”等待之后,最终的效果与Dormant-Back一样,都是显示用户切出应用时候的画面!
怪不得Activated 事件,提醒我们要注意以下黄底部分的文字
Activated 事件
当用户返回到休眠或逻辑删除的应用时,将调用 Activated
事件。应用应检查事件参数的 IsApplicationInstancePreserved
属性,以确定应用是从休眠状态返回,还是从逻辑删除状态返回。如果IsApplicationInstancePreserved 为 true,则应用之前处于休眠状态,状态已由操作系统自动保留。若为 false,则应用之前已被逻辑删除,应用应使用状态字典来还原应用程序状态。在执行Activated 事件处理程序期间,应用程序不应执行资源密集型任务(例如,从独立存储或网络资源加载内容),因为这会增加应用程序恢复所用的时间。而是应在加载应用程序之后,在后台线程中执行这些操作。由于在重新激活您的应用时,您在Deactivated
期间保存的状态字典将显示在内存中,您可以用这些字典来还原状态,而避免产生资源密集型文件操作的开销。
我自己的亲身调试经历也告诉我,当打开
调试——项目属性
勾选“在调试且停用时执行逻辑删除”
应用在切出切回后同样显示“正在恢复”
且等待少许时间
才能回到用户切出时候的画面
因此,验证了我的想法
另外,这个问题十分有趣
同样是采用墓碑机制,Windows Phone 8和iOS的多任务性能为什么会有较大的差别?
有兴趣的同学可以看一下
windows phone因为墓碑化导致“正在恢复”的分析的更多相关文章
- windows phone 墓碑化(9)
原文:windows phone 墓碑化(9) 几个术语的理解: 名称 说明 ; App ap = (App)Application.Current; // 构造函数 ...
- Windows 8 应用开发 - 挂起与恢复
原文:Windows 8 应用开发 - 挂起与恢复 Windows 8 应用通常涉及到两种数据类型:应用数据与会话数据.在上一篇提到的本地数据存储就是应用层面的数据,包括应用参数设置.用户重 ...
- Windows分页文件设置不当导致SQL Server服务被终止
Windows分页文件设置不当导致SQL Server服务被终止 文章说明 在正式开始验证和测试之前,先介绍Windows分页文件和SQL Server的动态内存管理.下面测试将分为两种测试场景:场景 ...
- windows系统与SQL SERVER 2008数据库服务性能监控分析简要
软件系统性能测试体系流程介绍之windows系统与SQL SERVER 2008数据库服务性能监控分析简要 目前大部分测试人员对操作系统资源.中间件.数据库等性能监控分析都是各自分析各自的监控指标方式 ...
- alias导致virtualenv异常的分析和解法
title: alias导致virtualenv异常的分析和解法 toc: true comments: true date: 2016-06-27 23:40:56 tags: [OS X, ZSH ...
- [转]DllMain中不当操作导致死锁问题的分析——DllMain中要谨慎写代码(完结篇)
在CSDN中发现这篇文章,讲解的比较详细,所以在这里备份一个.原文链接:http://blog.csdn.net/breaksoftware/article/details/8167641 DllMa ...
- 一步步实现windows版ijkplayer系列文章之六——SDL2源码分析之OpenGL ES在windows上的渲染过程
一步步实现windows版ijkplayer系列文章之一--Windows10平台编译ffmpeg 4.0.2,生成ffplay 一步步实现windows版ijkplayer系列文章之二--Ijkpl ...
- 使用Django.core.cache操作Memcached导致性能不稳定的分析过程
使用Django.core.cache操作Memcached导致性能不稳定的分析过程 最近测试一项目,用到了Nginx缓存服务,那可真是快啊!2Gb带宽都轻易耗尽. 不过Api接口无法简单使用Ngin ...
- 有效的结构化思维训练,MECE分析法
MECE原则,表达精准分类与全面性的有效利器 结构化思维的本质就是逻辑,其目的在于对问题的思考更完整.更有条理,它帮助我们一个一个找到线头,理清思路,探求事物之间的相互联系.MECE分析法是一种结构化 ...
随机推荐
- Android ToggleButton使用介绍
ToggleButton,就是开关按钮,包括选中和未选中状态,并且需要为不同的状态设置不同的事件处理: 例如:使用图片来展示ToggleButton不同的状态: MainActivity.java p ...
- HDU---4417Super Mario 树状数组 离线操作
题意:给定 n个数,查询 位置L R内 小于x的数有多少个. 对于某一次查询 把所有比x小的数 ”的位置“ 都加入到树状数组中,然后sum(R)-sum(L-1)就是答案,q次查询就要离线操作了,按高 ...
- hdu2460-Network:边的双连通分量
题目大意:给出一个无向图以及Q次询问,每次询问增加一条无向边,要求输出增加这条边后剩余的桥的数目. 算法:类似于求割点的方法,先做一次dfs求出所有的桥,并且维护这棵dfs树,当一次询问加入一条边(a ...
- QA笑话----杂思
QA工程师走进酒吧,要了一杯啤酒,要了0杯啤酒,要了999999999杯啤酒,要了一只蜥蜴,要了-1杯啤酒,要了一个sfdeljknesv,酒保从容应对,QA工程师 很满意.接下来,一名顾客来到了同一 ...
- 新闻:型牌男装:网上订服装,如何将返修率降到5个点以下 | IT桔子
新闻:型牌男装:网上订服装,如何将返修率降到5个点以下 | IT桔子 型牌男装:网上订服装,如何将返修率降到5个点以下
- day49
几天没写了 这几天比较麻木呢 各种课程的再看 想买一直不舍得money 今天下定决心买了 这样我也静下心好好备战把 一天背的东西好多 政治和作文也是背了就忘记 尽力把 今天的买的课很悬乎 就不在这说了 ...
- Android初学:联系创建Activity
public class Activity2 extends Activity{ @Override protected void onCreate(Bundle savedInstanceState ...
- APP常用模块
2016年上半年 APICloud合作云服务商提供了各种类型模块多达45个 其中最新发布的重要模块有 美洽客服模块 亲加视频直播相关模块 保利威视视频播放器模块 苹果银联支付模块 贝宝支付模块 谷歌分 ...
- Java 下各种设计模式小结
策略模式--定义算法族,分别封装起来,让它们之间能够互相替换,此模式让算法的变化独立于使用算法的客户. 策略模式是说,针对一种计算,定义一系列的算法,由用户决定详细使用哪一个算法完毕计算. 比 ...
- [RxJS] Error Handling in RxJS
Get your code back on the happy path! This lesson covers a variety of ways to handle exceptions thro ...