您的位置:首页 > 其它

如何提升在使用DevExpress 系列DataGrid的性能问题

2006-05-15 15:39 579 查看
通常我们需要成批在绑定的时候更新Grid里面的数据.

这时候两个方法尤其重要.

BeginUpdate();

EndUpdate();

这两个方法可以减少很多不必要的时间.

For ex:

改正前

PrintTicks("全选开始");
DevExpress.Data.ColumnSortOrder sortOrder = xtraGridView.Columns["colSelect"].SortOrder;
xtraGridView.Columns["colSelect"].SortOrder = DevExpress.Data.ColumnSortOrder.None;
xtraGridView.CloseEditor();
xtraGridView.UpdateCurrentRow();
//全选
int intRowCount = xtraGridView.RowCount;
for (int i = 0; i < intRowCount; i ++)
{
//取选择列并赋值
xtraGridView.GetDataRow(i)["colSelect"] = true;

}
xtraGridView.CloseEditor();
xtraGridView.UpdateCurrentRow();
xtraGridView.Columns["colSelect"].SortOrder = sortOrder;
PrintTicks("全选结束");

=================================================

 调整后

PrintTicks("全选开始");
int intRowCount = xtraGridView.RowCount;

//全选
//启动批量更新
xtraGridView.BeginUpdate();
for (int i = 0; i < intRowCount; i ++)
{
//取选择列并赋值
xtraGridView.GetDataRow(i)["colSelect"] = true;
}
//结束批量更新
xtraGridView.EndUpdate();

PrintTicks("全选结束");

性能差异:

  在Grid里面有100条以上的时候,第一种方法需要大概50秒,第二种方法用1秒.

  在SDK里面有讲到这个方法.

_uacct = "UA-269503-5";
urchinTracker();
内容来自用户分享和网络整理,不保证内容的准确性,如有侵权内容,可联系管理员处理 点击这里给我发消息
标签: 
相关文章推荐