『QQ:1353814576』

关于WPF中Frame使用新Page切换内存上涨问题


关于WPF中Frame使用Page切换内存上涨问题

最开始入行是做web开发的,刚接触wpf桌面开发项目的时候写过一个自助的桌面客户端,一堆花里胡哨的界面,页面切换采用了Frame内嵌Page的方式开发(因为和web比较相似就选了这种)

这里就分享一个初学者容易忽视的Frame嵌入Page使用内存问题 大概描述下遇到的情况


小伙伴反馈客户端运行一段时间后 客户端程序会自动崩溃,但远程盯了几个小时程序也没见程序异常退出,最开始以为是偶发性的系统故障就没理他,但是连续出了好几次,最终一次运气不错在小伙伴还没关掉崩溃的程序提示时看到了系统内存爆满

最后排查出来的原因居然是 Frame如果以new Page()的方式加载 后切换其他的新页面时 原来的内存并不会释放,也就是只要触发 Frame 加载新页面内存就会一直往上涨

因为单个页面内存占用并不高 所以平时测试也看不太出来,但是放到客户场地运行一段时间后 内存就不够用了(我这里触发条件是以用户点击加载新页面 然后点了一周系统内存就不够了)

解决办法:

切换页面不要每次都重新实例化一个新page,每个页面对应定义一个静态或者公用的参数