简体   繁体   中英

Casting an Item Collection from a listbox to a generic list

I want to find a better way of populating a generic list from a checkedlistbox in c#.

I can do the following easily enough:

List<string> selectedFields = new List<string>();

foreach (object a in chkDFMFieldList.CheckedItems) {
         selectedFields.Add(a.ToString());
         } 

There must be a more elagent method to cast the CheckedItems collection to my list.

Try this (using System.Linq):

OfType() is an extension method, so you need to use System.Linq

List<string> selectedFields = new List<string>();
selectedFields.AddRange(chkDFMFieldList.CheckedItems.OfType<string>());

Or just do it in one line:

List<string> selectedFields = chkDFMFieldList.CheckedItems.OfType<string>().ToList();

This is not exactly the answer to your requirement, but posting a more general answer. You could do it in a variety of ways:

1)

T[] items = new T[lb.Items.Count];
lb.Items.CopyTo(items, 0);
var lst = new List<T>(items);

2) looping and adding using foreach as you mentioned.

3) using Linq

var lst = lb.Items.Cast<T>().ToList();

4) or

var lst = lb.Items.OfType<T>().ToList();

When I did some performance testing like below, I found copying to array method the fastest while the Linq methods slower. Of course in real world scenarios these wouldnt matter. I prefer the 3rd method (Linq) for readability.

DateTime d = DateTime.Now;
for (int i = 0; i < 10000; i++)
{
    Action();
}
MessageBox.Show((DateTime.Now - d).TotalMilliseconds.ToString());

For an iteration of 10000 times run multiple times with about 300 items in list box,

1) ~100ms

2) ~150ms

3) ~250ms

4) ~260ms

如果您无权使用LINQ,那么没有一种更优雅的方法,因为除了填充selectedFields集合之外,您还在列表项上执行第二项操作(调用ToString() )。

The technical post webpages of this site follow the CC BY-SA 4.0 protocol. If you need to reprint, please indicate the site URL or the original address.Any question please contact:yoyou2525@163.com.

 
粤ICP备18138465号  © 2020-2024 STACKOOM.COM