Welcome to Software Development on Codidact!
Will you help us build our independent community of developers helping developers? We're small and trying to grow. We welcome questions about all aspects of software development, from design to code to QA and more. Got questions? Got answers? Got code you'd like someone to review? Please join us.
Do Where and OfType preserve List capacity?
Unless I am mistaken, myList.Select(a => a).ToList()
initializes the resulting list to the capacity of myList.Count
. Does myList.Where(a => true).ToList()
do so or does it build up from the initial capacity? What about OfType
?
1 answer
I did a quick test using LINQPad and it looks as though .Select()
does not necessarily preserve capacity. For .Where()
and .OfType()
the capacity depends on the count, though it doesn't necessarily match it. In my case .Select()
reduced the capacity to match the count. .Where()
and .OfType()
halved the capacity when it could contain the result, and preserved the capacity when it couldn't. This doesn't answer how it determines the exact capacity to use in any case.
List<object> fruits = new()
{
"Mango",
"Orange",
null,
"Apple",
3.0,
"Banana"
};
Console.WriteLine($"Original - Capactity: {fruits.Capacity}; Count: {fruits.Count()}");
List<object> everything = fruits.Select(x => x).ToList();
Console.WriteLine($"Selected - Capactity: {everything.Capacity}; Count: {everything.Count()}");
List<object> hasN = fruits.Where(x => x?.ToString()?.Contains("n") ?? false).ToList();
Console.WriteLine($"Whered - Capactity: {hasN.Capacity}; Count: {hasN.Count()}");
List<string> isString = fruits.OfType<string>().ToList();
Console.WriteLine($"OfTyped - Capactity: {isString.Capacity}; Count: {isString.Count()}");
List<object> notNull = fruits.Where(x => x != null).ToList();
Console.WriteLine($"Whered 2 - Capactity: {notNull.Capacity}; Count: {notNull.Count()}");
/* Output
Original - Capactity: 8; Count: 6
Selected - Capactity: 6; Count: 6
Whered - Capactity: 4; Count: 3
OfTyped - Capactity: 4; Count: 4
Whered 2 - Capactity: 8; Count: 5
*/
1 comment thread