WPF DataGrid与ListView性能对比与场景选择
开门见山的说

性能对比:
在Demo中,DataGrid与ListView默认开启虚拟化(可以理解为动态渲染,类似懒加载只渲染屏幕可以看见的地方)
DataGrid渲染10列50行随机字符280ms
ListView渲染10列50行随机字符80ms
场景选择:
ListView只生成需要展示的数据类型的控件,渲染相对DataGrid要快很多
DataGrid会生成编辑两种状态单元格(编辑与非编辑),如非必要不推荐使用(编辑单元格WPF硬伤/(ㄒoㄒ)/~~)
UI效果图:

Code:
XAML
<Window x:Class="WPFDemo.MainWindow" xmlns="http://schemas.microsoft.com/winfx/2006/xaml/presentation" xmlns:x="http://schemas.microsoft.com/winfx/2006/xaml" xmlns:d="http://schemas.microsoft.com/expression/blend/2008" xmlns:mc="http://schemas.openxmlformats.org/markup-compatibility/2006" xmlns:local="clr-namespace:WPFDemo" mc:Ignorable="d" Title="MainWindow" Height="450" Width="800">
<Grid>
<Grid.RowDefinitions>
<RowDefinition Height="40" />
<RowDefinition />
</Grid.RowDefinitions>
<WrapPanel VerticalAlignment="Center" HorizontalAlignment="Center">
<Button Margin="5,0" Width="80" Content="Next" Click="Button_Click"></Button>
<Label Content="DataGrid" Style="{x:Null}" VerticalAlignment="Center"></Label>
<Label Margin="5,0" Content="{Binding DgMs,UpdateSourceTrigger=PropertyChanged,Mode=TwoWay}" x:Name="uiDgMs"></Label>
<Label Content="ms" Style="{x:Null}" VerticalAlignment="Center"></Label>
<Label Margin="5,0,0,0" Content="ListView" Style="{x:Null}" VerticalAlignment="Center"></Label>
<Label Margin="5,0" Content="{Binding LvMs,UpdateSourceTrigger=PropertyChanged,Mode=TwoWay}" x:Name="uiLvMs"></Label>
<Label Content="ms" Style="{x:Null}" VerticalAlignment="Center"></Label>
</WrapPanel>
<TabControl Grid.Row="1">
<TabItem Header="DataGrid">
<DataGrid ItemsSource="{Binding DgList}" RowStyle="{x:Null}" AutoGenerateColumns="False" EnableColumnVirtualization="True" EnableRowVirtualization="True">
<DataGrid.Resources>
<Style TargetType="DataGridRow">
<Setter Property="Height" Value="24" />
</Style>
</DataGrid.Resources>
<DataGrid.Columns>
<DataGridTextColumn Header="F1" Binding="{Binding F1}"></DataGridTextColumn>
<DataGridTextColumn Header="F2" Binding="{Binding F2}"></DataGridTextColumn>
<DataGridTextColumn Header="F3" Binding="{Binding F3}"></DataGridTextColumn>
<DataGridTextColumn Header="F4" Binding="{Binding F4}"></DataGridTextColumn>
<DataGridTextColumn Header="F5" Binding="{Binding F5}"></DataGridTextColumn>
<DataGridTextColumn Header="F6" Binding="{Binding F6}"></DataGridTextColumn>
<DataGridTextColumn Header="F7" Binding="{Binding F7}"></DataGridTextColumn>
<DataGridTextColumn Header="F8" Binding="{Binding F8}"></DataGridTextColumn>
<DataGridTextColumn Header="F9" Binding="{Binding F9}"></DataGridTextColumn>
<DataGridTextColumn Header="F10" Binding="{Binding F10}"></DataGridTextColumn>
</DataGrid.Columns>
</DataGrid>
</TabItem>
<TabItem Header="ListView">
<ListView ItemsSource="{Binding LvList}">
<ListView.ItemContainerStyle>
<Style TargetType="ListViewItem">
<Setter Property="Height" Value="20" />
</Style>
</ListView.ItemContainerStyle>
<ListView.View>
<GridView>
<GridViewColumn Header="F1" DisplayMemberBinding="{Binding F1}"></GridViewColumn>
<GridViewColumn Header="F2" DisplayMemberBinding="{Binding F2}"></GridViewColumn>
<GridViewColumn Header="F3" DisplayMemberBinding="{Binding F3}"></GridViewColumn>
<GridViewColumn Header="F4" DisplayMemberBinding="{Binding F4}"></GridViewColumn>
<GridViewColumn Header="F5" DisplayMemberBinding="{Binding F5}"></GridViewColumn>
<GridViewColumn Header="F6" DisplayMemberBinding="{Binding F6}"></GridViewColumn>
<GridViewColumn Header="F7" DisplayMemberBinding="{Binding F7}"></GridViewColumn>
<GridViewColumn Header="F8" DisplayMemberBinding="{Binding F8}"></GridViewColumn>
<GridViewColumn Header="F9" DisplayMemberBinding="{Binding F9}"></GridViewColumn>
<GridViewColumn Header="F10" DisplayMemberBinding="{Binding F10}"></GridViewColumn>
</GridView>
</ListView.View>
</ListView>
</TabItem>
</TabControl>
</Grid>
</Window>
后台
using System;
using System.Collections.Generic;
using System.Diagnostics;
using System.Windows; namespace WPFDemo
{
/// <summary>
/// MainWindow.xaml 的交互逻辑
/// </summary>
public partial class MainWindow : Window
{
public MainWindow()
{
InitializeComponent();
view = new MainWindowView();
view.DgList = new System.Collections.ObjectModel.ObservableCollection<DgModel>();
this.DataContext = view;
InitData();
}
MainWindowView view;
private void InitData()
{
var list = new List<DgModel>();
Random rd = new Random();
for (int i = 0; i < 50; i++)
{
var item = new DgModel();
item.F1 = rd.Next().ToString();
item.F2 = rd.Next().ToString();
item.F3 = rd.Next().ToString();
item.F4 = rd.Next().ToString();
item.F5 = rd.Next().ToString();
item.F6 = rd.Next().ToString();
item.F7 = rd.Next().ToString();
item.F8 = rd.Next().ToString();
item.F9 = rd.Next().ToString();
item.F10 = rd.Next().ToString();
list.Add(item);
}
Stopwatch ms = new Stopwatch();
ms.Restart();
view.DgList = new System.Collections.ObjectModel.ObservableCollection<DgModel>(list);
ms.Stop();
view.DgMs = ms.ElapsedMilliseconds.ToString();
ms.Restart();
view.LvList = new System.Collections.ObjectModel.ObservableCollection<DgModel>(list);
ms.Stop();
view.LvMs = ms.ElapsedMilliseconds.ToString();
}
private void Button_Click(object sender, RoutedEventArgs e)
{
InitData();
}
}
}
相关回答:
ListView和ListBox的区别?(ListView是数据表格,ListBox是类似Tree的单选列表)
博主使用的是第三方开源控件HandyControl(强烈安利)
博客园空间不足,Demo加群下载
WPF DataGrid与ListView性能对比与场景选择的更多相关文章
- WPF DataGrid、ListView 简单绑定
DataGrid运行效果: xaml 代码: DataGridName= dtgData ItemsSource= {Binding} AutoGenerateColumns= False DataG ...
- 不同Framework下StringBuilder和String的性能对比,及不同Framework性能比(附Demo)
本文版权归mephisto和博客园共有,欢迎转载,但须保留此段声明,并给出原文链接,谢谢合作. 文章是哥(mephisto)写的,SourceLink 阅读目录 介绍 环境搭建 测试用例 MSDN说明 ...
- ArrayList和LinkedList的几种循环遍历方式及性能对比分析
最新最准确内容建议直接访问原文:ArrayList和LinkedList的几种循环遍历方式及性能对比分析 主要介绍ArrayList和LinkedList这两种list的五种循环遍历方式,各种方式的性 ...
- java中常见的json解析方法、库以及性能对比
常见的json解析有原生的JSONObject和JSONArray方法,谷歌的GSON库,阿里的fastjson,还有jackson,json-lib. Gson(项目地址:https://githu ...
- [原] KVM 环境下MySQL性能对比
KVM 环境下MySQL性能对比 标签(空格分隔): Cloud2.0 [TOC] 测试目的 对比MySQL在物理机和KVM环境下性能情况 压测标准 压测遵循单一变量原则,所有的对比都是只改变一个变量 ...
- 【腾讯Bugly干货分享】跨平台 ListView 性能优化
本文来自于腾讯Bugly公众号(weixinBugly),未经作者同意,请勿转载,原文地址:https://mp.weixin.qq.com/s/FbiSLPxFdGqJ00WgpJ94yw 导语 精 ...
- Android之ListView性能优化——一行代码绑定数据——万能适配器
如下图,加入现在有一个这样的需求图,你会怎么做?作为一个初学者,之前我都是直接用SimpleAdapter结合一个Item的布局来实现的,感觉这样实现起来很方便(基本上一行代码就可以实现),而且也没有 ...
- 浅谈C++之冒泡排序、希尔排序、快速排序、插入排序、堆排序、基数排序性能对比分析之后续补充说明(有图有真相)
如果你觉得我的有些话有点唐突,你不理解可以想看看前一篇<C++之冒泡排序.希尔排序.快速排序.插入排序.堆排序.基数排序性能对比分析>. 这几天闲着没事就写了一篇<C++之冒泡排序. ...
- Java--Stream,NIO ByteBuffer,NIO MappedByteBuffer性能对比
目前Java中最IO有多种文件读取的方法,本文章对比Stream,NIO ByteBuffer,NIO MappedByteBuffer的性能,让我们知道到底怎么能写出性能高的文件读取代码. pack ...
随机推荐
- 学习JUC源码(1)——AQS同步队列(源码分析结合图文理解)
前言 最近结合书籍<Java并发编程艺术>一直在看AQS的源码,发现AQS核心就是:利用内置的FIFO双向队列结构来实现线程排队获取int变量的同步状态,以此奠定了很多并发包中大部分实现基 ...
- 【学习笔记】最小直径生成树(MDST)
简介 无向图中某一点(可以在顶点上或边上),这个点到所有点的最短距离的最大值最小,那么这个点就是 图的绝对中心. 无向图所有生成树中,直径最小的一个,被称为 最小直径生成树. 图的绝对中心的求法 下文 ...
- 十、TestNG分组测试
使用 groups 属性 package com.lc.tesgFenZu; import org.testng.annotations.AfterGroups; import org.testng. ...
- 前端:css3的过渡与动画
一.css3过渡知识 (一).概述 1.CSS3过渡是元素从一种样式逐渐改变为另一种的效果. 2.实现过渡效果的两个要件: 规定把效果添加到那个css属性上. 规定效果时长 定义 ...
- Web常用编码以及攻击绕过笔记
一.URL编码形式:"%"加上ASCII码(先将字符转换为两位ASCII码,再转为16进制),其中加号"+"在URL编码中和"%20"表示一 ...
- 关于 ReentrantLock 中锁 lock() 和解锁 unlock() 的底层原理浅析
关于 ReentrantLock 中锁 lock() 和解锁 unlock() 的底层原理浅析 如下代码,当我们在使用 ReentrantLock 进行加锁和解锁时,底层到底是如何帮助我们进行控制的啦 ...
- [WPF] 在 ViewModel 中让数据验证出错(Validation.HasError)的控件获得焦点
1. 需求 在 MVVM 中 ViewModel 和 View 之间的交互通常都是靠 Icommand 和 INotifyPropertyChanged,不过有时候还会需要从 MVVM 中控制 Vie ...
- python初学者-计算1-99奇数的和
s = 0 for i in range(1,100,2): s = s + i print(s)
- 微信小程序--相对路径和绝对路径
相对路径: ../表示返回访问上一级目录 如:../../components/like/index 绝对路径: 以"/"开头 表示从根目录开始寻找文件 如:/components ...
- CentOS7的防火墙以及selinux介绍/安装telnet命令/安装netstat与ifconfig命令
简介:firewall防火墙的使用 防火墙:主要用户信息安全防护,主要有软件防火墙和硬件防火墙.firewalld防火墙是软件防火墙,在centos7 之前默认采用的防火墙是iptables,而在ce ...