开门见山的说

性能对比:

在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性能对比与场景选择的更多相关文章

  1. WPF DataGrid、ListView 简单绑定

    DataGrid运行效果: xaml 代码: DataGridName= dtgData ItemsSource= {Binding} AutoGenerateColumns= False DataG ...

  2. 不同Framework下StringBuilder和String的性能对比,及不同Framework性能比(附Demo)

    本文版权归mephisto和博客园共有,欢迎转载,但须保留此段声明,并给出原文链接,谢谢合作. 文章是哥(mephisto)写的,SourceLink 阅读目录 介绍 环境搭建 测试用例 MSDN说明 ...

  3. ArrayList和LinkedList的几种循环遍历方式及性能对比分析

    最新最准确内容建议直接访问原文:ArrayList和LinkedList的几种循环遍历方式及性能对比分析 主要介绍ArrayList和LinkedList这两种list的五种循环遍历方式,各种方式的性 ...

  4. java中常见的json解析方法、库以及性能对比

    常见的json解析有原生的JSONObject和JSONArray方法,谷歌的GSON库,阿里的fastjson,还有jackson,json-lib. Gson(项目地址:https://githu ...

  5. [原] KVM 环境下MySQL性能对比

    KVM 环境下MySQL性能对比 标签(空格分隔): Cloud2.0 [TOC] 测试目的 对比MySQL在物理机和KVM环境下性能情况 压测标准 压测遵循单一变量原则,所有的对比都是只改变一个变量 ...

  6. 【腾讯Bugly干货分享】跨平台 ListView 性能优化

    本文来自于腾讯Bugly公众号(weixinBugly),未经作者同意,请勿转载,原文地址:https://mp.weixin.qq.com/s/FbiSLPxFdGqJ00WgpJ94yw 导语 精 ...

  7. Android之ListView性能优化——一行代码绑定数据——万能适配器

    如下图,加入现在有一个这样的需求图,你会怎么做?作为一个初学者,之前我都是直接用SimpleAdapter结合一个Item的布局来实现的,感觉这样实现起来很方便(基本上一行代码就可以实现),而且也没有 ...

  8. 浅谈C++之冒泡排序、希尔排序、快速排序、插入排序、堆排序、基数排序性能对比分析之后续补充说明(有图有真相)

    如果你觉得我的有些话有点唐突,你不理解可以想看看前一篇<C++之冒泡排序.希尔排序.快速排序.插入排序.堆排序.基数排序性能对比分析>. 这几天闲着没事就写了一篇<C++之冒泡排序. ...

  9. Java--Stream,NIO ByteBuffer,NIO MappedByteBuffer性能对比

    目前Java中最IO有多种文件读取的方法,本文章对比Stream,NIO ByteBuffer,NIO MappedByteBuffer的性能,让我们知道到底怎么能写出性能高的文件读取代码. pack ...

随机推荐

  1. CF850F Rainbow Balls 题解

    考虑最后变成哪一种颜色. 设 \(s = \sum\limits_{i=1}^n a_i\) 设现在有 \(k\) 种当前颜色, 需要全部变成该种颜色, 期望步数为 \(f_k\). 考虑状态转移.设 ...

  2. SP7022 CPATTERN - Cow Patterns

    本篇题解用于作者本人加深理解,也欢迎大家阅读. 这道题的正解是\(KMP\)加上树状数组,记录每一个位置前几个位置比其小的.相等的.大的数的数量,比较方式便是比较相应的数量,若相等,则匹配成功. 但是 ...

  3. gunicorn简单配置

    Gunicorn配置 # -*- coding: utf-8 -*- import os from multiprocessing import cpu_count bind = "127. ...

  4. Echarts入门教程精简实用系列

    引语:echarts.js是百度团队推出的一款用于图表可视化的插件,用于以图表的形式展现数据,功能强大,上手简单 1.从官方网站中下载所需的echarts.js文件,该文件因功能广泛,包体较大,可自行 ...

  5. 访问控制列表ACL应用

    ACL的应用的场景 应用在三层接口 • Nat地址转换 Nat(network address translation,地址转换)是将数据报报头中的ip地址转换为另一个ip地址的过程,主要用于实现内部 ...

  6. linux 配置本地yum源,配置国内yum源,配置epel源

    目录 一.配置本地yum源 二.配置国内yum源和epel源 一.配置本地yum源 1.挂载ISO镜像 mount -o loop /mnt/yum-iso/CentOS-7-x86_64-DVD-1 ...

  7. Flink批处理读写Hive

    import org.apache.flink.table.api.*; import org.apache.flink.table.catalog.hive.HiveCatalog; /** * @ ...

  8. matplotlib的学习5-legend图例

    import matplotlib.pyplot as plt import numpy as np ''' legend 图例就是为了帮我们展示出每个数据对应的图像名称. 更好的让读者认识到你的数据 ...

  9. C++webservice接口调用

    一.WebService例子 1.准备要调用的webservice接口的wsdl地址,比如网上的查询天气接口:http://ws.webxml.com.cn/WebServices/WeatherWS ...

  10. Raft算法系列教程2:状态机复制 (State Machine Replication)

    分区容错如何保证? 在分布式系统设计中,需要遵循CAP理论,如果我们要让一个服务具有容错能力,那么最常用最直接的办法就是让一个服务的多个副本同时运行在不同的节点上.但是,当一个服务的多个副本都在运行的 ...