Logo Questions Linux Laravel Mysql Ubuntu Git Menu
 

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.

like image 353
Alex Avatar asked Jan 23 '09 01:01

Alex


3 Answers

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();
like image 59
Matt Hamilton Avatar answered Sep 30 '22 11:09

Matt Hamilton


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

like image 27
nawfal Avatar answered Oct 04 '22 11:10

nawfal


If you don't have access to LINQ then there isn't a more elegant way since you're performing a second operation on the list items (calling ToString()) in addition to populating the selectedFields collection.

like image 24
Ken Browning Avatar answered Oct 03 '22 11:10

Ken Browning