看一段代码:
StringCollection arr
=
new
StringCollection();
for ( int i = 0 ;i <= lvwExtents.CheckedItems - 1 ;i ++ )
{
arr.Add(lvwExtents.CheckedItems[i].Text);
}
for ( int i = 0 ;i <= lvwExtents.CheckedItems - 1 ;i ++ )
{
arr.Add(lvwExtents.CheckedItems[i].Text);
}
看上去没什么问题。可是今天我运行时,发现速度缓慢得像蜗牛一般。我的ListView有两千多条记录,全部处于选中状态。速度无法忍受,估计秒种处理的记录只有两三条。
可是换成了以下代码后,就完全正常了,飞快的就执行完了。
ListViewItem item;
for ( int i = 0 ;i <= this .lvwExtents.Items.Count - 1 ;i ++ )
{
item = this .lvwExtents.Items[i];
if (item.Checked)
arr.Add(item.Text);
}
for ( int i = 0 ;i <= this .lvwExtents.Items.Count - 1 ;i ++ )
{
item = this .lvwExtents.Items[i];
if (item.Checked)
arr.Add(item.Text);
}
奇怪吧。也许是因为每次循环时调用的lvwExtents.CheckedItems[i].Text代码,都会重新检测哪些项处于选中的状态的缘故吧。
CheckedItems 属性返回一个集合,该集合包含控件中的所有选中项。
第一种实现方法 每次循环它都会去获取lvwExtents中的所有选中项.然后再取得当前i的索引值.可以这样讲其时间复杂度为O(N2)(因为CheckedItems属性封装了其取得所有选中的算法).而第二种方法其时间复杂度为O(N).
下面是第三种实现方法:楼主可以试试,其性能将会更好.
IList mList=lvwExtents.CheckedItems;
int ItemCount=mList.Count;
for(int i=0;i<ItemCount;i++)
{
arr.Add(((ListViewItem)mList[i])).Text)
}
转自http://www.cnblogs.com/watsonyin/archive/2006/11/02/548197.html#1521894