Windows phone 7 90M内存限制问题及设计原则
一. 在wp7中,程序所使用内存不能超过90M, 否则会自动退出。
二. 如果一个page没有被释放,那么它所包含的所有控件资源都不会被垃圾收集.
在wp7中操作图像资源是很费内存的,而我们在XAML文件中定义的Image控件,由于属于静态资源。
所以你不可能在后台CS代码中对它们进行image.source = null 操作。
除非你把Image控件的定义放在CS代码中,
这样你执行image.source = null 操作或者
将Image控件从LayoutRoot中卸掉:LayoutRoot.Children.Remove(Image),
那么这个image就会被垃圾收集。
因此,对于在XAML文件中定义的图像控件来说,
要想释放这些图像所占用的内存,唯一时刻只能是离开这个Page的时刻。
所以,一条重要原则:尽量不要将一个包含大量图像控件的page作为你的MainPage,
因为这个Page会等到整个程序结束(exit)的时候才会被释放。
所以建议就是:
1.如果程序有主界面的话,尽量不要在主界面上放太多图像控件。
或者说不要将一个拥有大量图像的page作为main page。
2.尽可能将需要播放动画并包含大量图像的page单独做成一个page,
播放完毕或者用完就离开这个page。
3.Panorama 的background 如果设置成图像image的话,会消耗大量内存。
一般24M左右,而且跟是否是jpg或png, 跟图像大小和复杂度也没关系。
唯一能降低内存消耗的方法是讲panorama的高度(height)减小,
比如减小一半,那么内存消耗也会减小一般,因为它只绘制了一半在界面上。
你可能会想到将panorama的背景设置成渐变,我试过,这样也会消耗17M内存。
如果设置成单色(solid color brush),大约消耗2-3M左右。
唯一不会消耗内存的就是:no background.
因此,请在选用Panorama之前,好好检查一下你的程序当前已经消耗了多少内存。
余下的内存还够不够你load 一个panorama大胃王。
4.听说Pivot也是个让人又爱又恨的东西,
在你加了很多tab到一个pivot中,而且图像又太多时,它也可能挂。
另外,附送一段代码,让你知道在WP7中,如何让你知道每个Page何时被释放?
#if(DEBUG) /// <summary> /// Add a finalizer to check for memory leaks /// </summary> ~YourPage() { System.Diagnostics.Debug.WriteLine("Finalizing " + this.GetType().FullName); } #endif
你可以将这段代码添加到你的每一个page中,记得修改这个析构函数的名称哦。
那么当这个page被析构的时候,就会在output控制台里看到。