WPF优化体验<一>

最近将一个开发和维护了五年的一个Winform项目进行重构,考虑到最近很流行将用户体验挂在嘴上,因而采用了WPF技术,但愿能在外观和体验上有一个全新的效果。windows

之前使用Winform的时候内存控制得不错,软件使用一天下来也就100M左右,如今使用WPF,十分钟就达到了100M,在感慨WPF的胃口之余也在思考怎样将内存占用量降下去。ide

首先写了一个测试项目,放两个窗体。第一个窗体放一个DataGrid,里面绑定200条数据,第二个窗体放两个测试按钮,按钮点击代码以下。测试

        //打开20个测试窗口
        List<TestWindow> windows = new List<TestWindow>();
        private void Button1_Click(object sender, RoutedEventArgs e)
        {
            for (int i = 0; i < 20; i++)
            {
                var window = new TestWindow();
                windows.Add(window);
                window.Show();
            }
        }

        //关闭当前打开的测试窗口
        private void Button2_Click(object sender, RoutedEventArgs e)
        {
            foreach (var item in windows)
            {
                item.Close();
            }
        }

        //调用垃圾回收器,强制回收可用内存
        private void Button3_Click(object sender, RoutedEventArgs e)
        {
            GC.Collect();
        }

 如今准备开始测试:优化

点击Button1打开20个测试窗口,此时内存便达到了126M,点击Button2,关闭全部测试窗体,内存110M,再次打开20个测试窗体,内存205M,关闭全部窗体,内存185M,条用垃圾回收,内存139Mthis

将程序稍微改动了一下,关闭测试窗体时,将数据上下文绑定(DataContext)赋值为空,继续测试spa

点击Button1打开20个测试窗口,此时内存便达到了123M,点击Button2,关闭全部测试窗体,内存110M,再次打开20个测试窗体,内存136M,关闭全部窗体,内存120M,条用垃圾回收,内存55Morm

 进行了屡次测试,结果数据基本一致,为了更直观的对数据有一个比较,现将数据列表以下:blog

  程序运行 打开20个测试窗体 关闭20个测试窗体 再次打开20个测试窗体 再次关闭20个测试窗体 强制垃圾回收
关闭窗体时不作处理 17M 126M 110M 205M 185M 139M
关闭窗体时将DataContext赋空值 17M 123M 110M 136M 120M 55M

因此,结论只有一个,当咱们使用MVVM模式绑定DataContext或是直接给列表控件绑定数据源的状况下,关闭窗体时,最好将绑定属性赋一个空值内存

        protected override void OnClosed(EventArgs e)
        {
            base.OnClosed(e);
            this.DataContext = null;
        }

 

之后会继续博文,将亲身经历的WPF优化方案提出来,和你们一块儿探讨。ci

相关文章
相关标签/搜索