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控制台里看到。

posted @ 2012-03-12 09:55  sphinx007  阅读(707)  评论(0编辑  收藏  举报