array(2) { ["docs"]=> array(10) { [0]=> array(10) { ["id"]=> string(3) "428" ["text"]=> string(77) "Visual Studio 2017 单独启动MSDN帮助(Microsoft Help Viewer)的方法" ["intro"]=> string(288) "目录 ECharts 异步加载 ECharts 数据可视化在过去几年中取得了巨大进展。开发人员对可视化产品的期望不再是简单的图表创建工具,而是在交互、性能、数据处理等方面有更高的要求。 chart.setOption({ color: [ " ["username"]=> string(8) "DonetRen" ["tagsname"]=> string(55) "Visual Studio 2017|MSDN帮助|C#程序|.NET|Help Viewer" ["tagsid"]=> string(23) "[401,402,403,"300",404]" ["catesname"]=> string(0) "" ["catesid"]=> string(2) "[]" ["createtime"]=> string(10) "1511400964" ["_id"]=> string(3) "428" } [1]=> array(10) { ["id"]=> string(3) "427" ["text"]=> string(42) "npm -v;报错 cannot find module "wrapp"" ["intro"]=> string(288) "目录 ECharts 异步加载 ECharts 数据可视化在过去几年中取得了巨大进展。开发人员对可视化产品的期望不再是简单的图表创建工具,而是在交互、性能、数据处理等方面有更高的要求。 chart.setOption({ color: [ " ["username"]=> string(4) "zzty" ["tagsname"]=> string(50) "node.js|npm|cannot find module "wrapp“|node" ["tagsid"]=> string(19) "[398,"239",399,400]" ["catesname"]=> string(0) "" ["catesid"]=> string(2) "[]" ["createtime"]=> string(10) "1511400760" ["_id"]=> string(3) "427" } [2]=> array(10) { ["id"]=> string(3) "426" ["text"]=> string(54) "说说css中pt、px、em、rem都扮演了什么角色" ["intro"]=> string(288) "目录 ECharts 异步加载 ECharts 数据可视化在过去几年中取得了巨大进展。开发人员对可视化产品的期望不再是简单的图表创建工具,而是在交互、性能、数据处理等方面有更高的要求。 chart.setOption({ color: [ " ["username"]=> string(12) "zhengqiaoyin" ["tagsname"]=> string(0) "" ["tagsid"]=> string(2) "[]" ["catesname"]=> string(0) "" ["catesid"]=> string(2) "[]" ["createtime"]=> string(10) "1511400640" ["_id"]=> string(3) "426" } [3]=> array(10) { ["id"]=> string(3) "425" ["text"]=> string(83) "深入学习JS执行--创建执行上下文(变量对象,作用域链,this)" ["intro"]=> string(288) "目录 ECharts 异步加载 ECharts 数据可视化在过去几年中取得了巨大进展。开发人员对可视化产品的期望不再是简单的图表创建工具,而是在交互、性能、数据处理等方面有更高的要求。 chart.setOption({ color: [ " ["username"]=> string(7) "Ry-yuan" ["tagsname"]=> string(33) "Javascript|Javascript执行过程" ["tagsid"]=> string(13) "["169","191"]" ["catesname"]=> string(0) "" ["catesid"]=> string(2) "[]" ["createtime"]=> string(10) "1511399901" ["_id"]=> string(3) "425" } [4]=> array(10) { ["id"]=> string(3) "424" ["text"]=> string(30) "C# 排序技术研究与对比" ["intro"]=> string(288) "目录 ECharts 异步加载 ECharts 数据可视化在过去几年中取得了巨大进展。开发人员对可视化产品的期望不再是简单的图表创建工具,而是在交互、性能、数据处理等方面有更高的要求。 chart.setOption({ color: [ " ["username"]=> string(9) "vveiliang" ["tagsname"]=> string(0) "" ["tagsid"]=> string(2) "[]" ["catesname"]=> string(8) ".Net Dev" ["catesid"]=> string(5) "[199]" ["createtime"]=> string(10) "1511399150" ["_id"]=> string(3) "424" } [5]=> array(10) { ["id"]=> string(3) "423" ["text"]=> string(72) "【算法】小白的算法笔记:快速排序算法的编码和优化" ["intro"]=> string(288) "目录 ECharts 异步加载 ECharts 数据可视化在过去几年中取得了巨大进展。开发人员对可视化产品的期望不再是简单的图表创建工具,而是在交互、性能、数据处理等方面有更高的要求。 chart.setOption({ color: [ " ["username"]=> string(9) "penghuwan" ["tagsname"]=> string(6) "算法" ["tagsid"]=> string(7) "["344"]" ["catesname"]=> string(0) "" ["catesid"]=> string(2) "[]" ["createtime"]=> string(10) "1511398109" ["_id"]=> string(3) "423" } [6]=> array(10) { ["id"]=> string(3) "422" ["text"]=> string(64) "JavaScript数据可视化编程学习(二)Flotr2,雷达图" ["intro"]=> string(288) "目录 ECharts 异步加载 ECharts 数据可视化在过去几年中取得了巨大进展。开发人员对可视化产品的期望不再是简单的图表创建工具,而是在交互、性能、数据处理等方面有更高的要求。 chart.setOption({ color: [ " ["username"]=> string(7) "chengxs" ["tagsname"]=> string(28) "数据可视化|前端学习" ["tagsid"]=> string(9) "[396,397]" ["catesname"]=> string(18) "前端基本知识" ["catesid"]=> string(5) "[198]" ["createtime"]=> string(10) "1511397800" ["_id"]=> string(3) "422" } [7]=> array(10) { ["id"]=> string(3) "421" ["text"]=> string(36) "C#表达式目录树(Expression)" ["intro"]=> string(288) "目录 ECharts 异步加载 ECharts 数据可视化在过去几年中取得了巨大进展。开发人员对可视化产品的期望不再是简单的图表创建工具,而是在交互、性能、数据处理等方面有更高的要求。 chart.setOption({ color: [ " ["username"]=> string(4) "wwym" ["tagsname"]=> string(0) "" ["tagsid"]=> string(2) "[]" ["catesname"]=> string(4) ".NET" ["catesid"]=> string(7) "["119"]" ["createtime"]=> string(10) "1511397474" ["_id"]=> string(3) "421" } [8]=> array(10) { ["id"]=> string(3) "420" ["text"]=> string(47) "数据结构 队列_队列实例:事件处理" ["intro"]=> string(288) "目录 ECharts 异步加载 ECharts 数据可视化在过去几年中取得了巨大进展。开发人员对可视化产品的期望不再是简单的图表创建工具,而是在交互、性能、数据处理等方面有更高的要求。 chart.setOption({ color: [ " ["username"]=> string(7) "idreamo" ["tagsname"]=> string(40) "C语言|数据结构|队列|事件处理" ["tagsid"]=> string(23) "["246","247","248",395]" ["catesname"]=> string(12) "数据结构" ["catesid"]=> string(7) "["133"]" ["createtime"]=> string(10) "1511397279" ["_id"]=> string(3) "420" } [9]=> array(10) { ["id"]=> string(3) "419" ["text"]=> string(47) "久等了,博客园官方Android客户端发布" ["intro"]=> string(288) "目录 ECharts 异步加载 ECharts 数据可视化在过去几年中取得了巨大进展。开发人员对可视化产品的期望不再是简单的图表创建工具,而是在交互、性能、数据处理等方面有更高的要求。 chart.setOption({ color: [ " ["username"]=> string(3) "cmt" ["tagsname"]=> string(0) "" ["tagsid"]=> string(2) "[]" ["catesname"]=> string(0) "" ["catesid"]=> string(2) "[]" ["createtime"]=> string(10) "1511396549" ["_id"]=> string(3) "419" } } ["count"]=> int(200) } 222 Windows Phone 7(WP7)开发 Loaded VS OnNavigatedTo - 爱码网

本来想中午就更新一篇文章的,结果这都下午三点半多了,刚才一个小问题一直困扰了我很长时间,刚才经过努力终于是解决了(嗯,应该是解决了吧,还有待更多时间的测试)。

具体问题,我在我的应用的主页面需要获取手机的GPS位置信息,并通过网络API转换成地理位置,然后把这个值绑定到一个控件上面显示出来。 很简单,不是么,所以我就直接在首页的Loaded里面调用了这些需要的方法,其实写这个功能用不了太多的代码,但是当我写完之后我发现,我的程序变得非常的不稳定,80%的情况下是好的,而有的时候界面就会卡住不动。具体表现为退出程序之后重新打开,有的时候界面就处于卡死状态,直到系统强行结束掉我的程序。甚至有的时候直接在VS里面连接真机调试,就卡在首页不动。

有的朋友该说了:你没有用多线程吧?如果请求GPS和请求网络等等都在UI线程里进行,那肯定是要卡死的啊。

我确定,我已经手工写了新的进程了。我也试图用断点跟踪调试到底是哪里出现了问题, 但是终无所获。

由于接近80%的情况下没有异常反应,所以这个问题处理的优先级并不高,但我知道有这么一个BUG总感觉不爽,确实是很不爽啊。

直到一个小时之前,我突然想到了解决办法:

我把上面在Loaded里面做的事情,全部转移到了OnNavigatedTo里面来做,之后测试了数次,均表现正常(如果不出意外,相信我已经找到了正确的解决方法)。

 

上面罗嗦了一大堆,反思一下并引入正题:Loaded VS OnNavigatedTo

做WinForm或ASP.NET的朋友在处理页面初始化的问题上一般都是习惯在Loaded里面做事情,当然我也不例外。不过在WP7上,看来需要注意一下了。现在分析我刚才遇到的问题,我隐约觉得可能是Load里写的东西和加载界面的数据绑定产生了冲突,或者是资源死锁,当然,这个具体原因我无法给出准确的判断,这个只是感觉。

         XXX_Loaded和OnNavigatedTo都是在页面“载入”时触发的(我这里说的载入是指对用户来说,即他们看到界面展示在他们之前),这个可以称为他们的共同点,他们共同使用本页面的资源。至于不同点,XXX_Loaded方法并非每次页面激活而执行,这个估计由系统调度,而OnNavigatedTo方法则在每次页面激活的时候都会执行。还有就是它们的先后顺序,我个人认为(为了怕误导大家先写“个人认为”,等查到确切资料再改)应该是Loaded在前,OnNavigatedTo在后,Loaded执行之时就是页面正在载入的时候,OnNavigatedTo执行的时候应该是页面完全载入完毕了。 刚才还准备查查资料,结果就有朋友提出OnNavigatedTo比Loaded早(感谢“阿干@NET”),马上写了两行程序测试了一下,发现确实如此,写程序不能靠感觉啊~那刚才我遇到的问题,估计就是线程冲突而导致资源死锁(继续标注“可能是”),而OnNavigatedTo在前,似乎就对这种情况进行了避免。刚才写完文章之后也百度了一下,发现很多朋友多认为页面里还是用OnNavigatedTo比Loaded好一些。

所以,以后涉及到界面上绑定的数据的变量的值的获取,最好还是写到OnNavigatedTo里面吧。当然,如果你想只执行一次,比如我上面的GPS位置只需要获取一次就够了,那也容易:

 

 private bool _isFirst = true;

        protected override void OnNavigatedTo(System.Windows.Navigation.NavigationEventArgs e)
        {
            base.OnNavigatedTo(e);
            if (_isFirst)
            {
               //TODO:.......
                _isFirst = false;
            }
        }

相关文章: