我们在平时的WP使用过程中,会遇到一个问题

应用在切出,切回后,

  1. 有时候,会显示“正在恢复”,并等待时间较长,才能回到用户切出时候的画面,但是这种情况并非常见,偶尔发生
  2. 有时候,直接回到切出时的画面,反应还蛮迅速的

这是为什么那?

我做了研究,分析如下:

首先,我们看一下WP的生命周期

(详情见:App activation and deactivation for Windows Phone 8)



当应用因为

  1. 用户点击WIN键
  2. 发送短信,跳往WIFI设置,或者其他Task

切出应用后,会触发事件Deactivated,失活,也就是不在前台显示了

然后,

这里是关键

存在两个状态

  1. Dormant
  2. 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 期间填充应用的状态字典。设备每次最多可维护五个应用的逻辑删除信息。如果在逻辑删除应用之后,用户向后导航至应用程序,则应用程序将会重新启动并使用保留的数据还原状态。

回到问题

应用在切出,切回后,

  1. 有时候,会显示“正在恢复”,并等待时间较长,才能回到用户切出时候的画面,但是这种情况并非常见,偶尔发生
  2. 有时候,直接回到切出时的画面,反应还蛮迅速的

我认为,

这是因为两种不同的状态返回了应用而致:

应用是从休眠状态重新激活的,则无需执行任何操作来重建状态,因为状态已被保留。

于是这样发生了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因为墓碑化导致“正在恢复”的分析的更多相关文章

  1. windows phone 墓碑化(9)

    原文:windows phone 墓碑化(9) 几个术语的理解: 名称 说明 ;        App ap = (App)Application.Current;        // 构造函数    ...

  2. Windows 8 应用开发 - 挂起与恢复

    原文:Windows 8 应用开发 - 挂起与恢复      Windows 8 应用通常涉及到两种数据类型:应用数据与会话数据.在上一篇提到的本地数据存储就是应用层面的数据,包括应用参数设置.用户重 ...

  3. Windows分页文件设置不当导致SQL Server服务被终止

    Windows分页文件设置不当导致SQL Server服务被终止 文章说明 在正式开始验证和测试之前,先介绍Windows分页文件和SQL Server的动态内存管理.下面测试将分为两种测试场景:场景 ...

  4. windows系统与SQL SERVER 2008数据库服务性能监控分析简要

    软件系统性能测试体系流程介绍之windows系统与SQL SERVER 2008数据库服务性能监控分析简要 目前大部分测试人员对操作系统资源.中间件.数据库等性能监控分析都是各自分析各自的监控指标方式 ...

  5. alias导致virtualenv异常的分析和解法

    title: alias导致virtualenv异常的分析和解法 toc: true comments: true date: 2016-06-27 23:40:56 tags: [OS X, ZSH ...

  6. [转]DllMain中不当操作导致死锁问题的分析——DllMain中要谨慎写代码(完结篇)

    在CSDN中发现这篇文章,讲解的比较详细,所以在这里备份一个.原文链接:http://blog.csdn.net/breaksoftware/article/details/8167641 DllMa ...

  7. 一步步实现windows版ijkplayer系列文章之六——SDL2源码分析之OpenGL ES在windows上的渲染过程

    一步步实现windows版ijkplayer系列文章之一--Windows10平台编译ffmpeg 4.0.2,生成ffplay 一步步实现windows版ijkplayer系列文章之二--Ijkpl ...

  8. 使用Django.core.cache操作Memcached导致性能不稳定的分析过程

    使用Django.core.cache操作Memcached导致性能不稳定的分析过程 最近测试一项目,用到了Nginx缓存服务,那可真是快啊!2Gb带宽都轻易耗尽. 不过Api接口无法简单使用Ngin ...

  9. 有效的结构化思维训练,MECE分析法

    MECE原则,表达精准分类与全面性的有效利器 结构化思维的本质就是逻辑,其目的在于对问题的思考更完整.更有条理,它帮助我们一个一个找到线头,理清思路,探求事物之间的相互联系.MECE分析法是一种结构化 ...

随机推荐

  1. linux下串口的阻塞和非阻塞操作

    有两个可以进行控制串口阻塞性(同时控制read和write):一个是在打开串口的时候,open函数是否带O_NDELAY:第二个是可以在打开串口之后通过fcntl()函数进行控制. 阻塞的定义: 对于 ...

  2. Jetty直接调试,不用部署,不用弄一些杂七杂八的设置

    以前调试web程序的,搭建Tomcat实在是费劲,就想找一个比较简单的方式,我就想调试一下我写的某一个servlet形式,看到<how Tomcat works>这本书,才明白确实可以,不 ...

  3. JS~对img标签进行优化,使用onerror进行默认图像显示

    对于网站图像的不显示有很多原因,网络问题,文件本身问题,文件URL问题等,而当图像加载失败时会触发onerror这个事件,我们利用这点,可以有效的避免图像加载失败的尴尬! JS代码 //图像加载出错时 ...

  4. javascript将毫秒还原为可读时间格式

    <script type="text/javascript"> //随便设置一个时间 var otime = new Date("2015-11-11 20: ...

  5. VPN错误789:L2TP连接尝试失败

    VPN 错误789:l2tp 连接尝试失败,因为安全层在初始化与远程计算机的协商时遇到一个处理错误 Windows配置VPN,选择“使用IPsec的第2层隧道协议(L2TP/IPSec)”时, XP系 ...

  6. 使用cocoapods后 三方库的头文件没有代码提示?

    选择Target -> Build Settings 菜单,找到\”User Header Search Paths\”设置项 新增一个值"${SRCROOT}",并且选择\ ...

  7. URI和URL

    URI(uniform resource identifier),统一资源标识符,用来唯一的标识一个资源. URL(uniform resource locator),统一资源定位器,它是一种具体的U ...

  8. WARNING: The following packages cannot be authenticated! foo bar baz Install these packages without verification [y/N]?

    apt-get install debian-archive-keyring apt-get update

  9. C/C++中的switch使用

    代码: #include <iostream> #include <string> #include <cstdio> using namespace std; i ...

  10. C/C++:Unions 联合

    原文:http://msdn.microsoft.com/en-us/library/5dxy4b7b(v=vs.80).aspx 联合是用户定义的数据或类类型,在任何时间里,它只包含成员列表中的一个 ...