LINQ Mastery

OfType vs Cast: Handling heterogeneous collections

1 Views Updated 5/4/2026

Filtering by Type

When working with object collections (like UI controls or base class lists), you often need to grab just the specific types. OfType and Cast look similar but behave very differently.

1. OfType: The Secure Filter

OfType<T>() checks each element. If it matches the type, it yields it. If it DOESN'T match, it simply **skips** it gracefully. Use this when your list is a mix of types.

2. Cast: The Optimistic Transformer

Cast<T>() tries to force every element into the target type. If a single element fails to cast, it throws an InvalidCastException. Use this only when you are 100% sure the collection contains only that type.

3. Architect Insight

Q: "Which is better for legacy code?"

Architect Answer: "Legacy collections from .NET 1.1 (like ArrayList) don't support generics. Use **Cast** to convert them into IEnumerable<T> so you can use modern LINQ methods. For modern collections, prefer **OfType** as it's more resilient to unexpected data."

LINQ Mastery
General
Introduction to LINQ Mastery
1. Core Foundations
LINQ Fundamentals: Why LINQ? IQueryable vs IEnumerable: The Architect's choice Expression Trees: The power behind LINQ providers Method Syntax vs Query Syntax: Trade-offs
2. Filtering & Transformation
Where & Select: The bread and butter SelectMany: Flattening complex hierarchies OfType vs Cast: Handling heterogeneous collections Distinct & DistinctBy: Mastering unique sets
3. Aggregation & Quantifiers
Any, All, Contains: The boolean quantifiers Count, LongCount, Sum: Basic aggregations Min, Max, Average: Statistical operations Aggregate: The 'Fold' function of .NET
4. Ordering & Partitioning
OrderBy & OrderByDescending: Sorting data ThenBy: Multi-level sorting Take & Skip: Pagination strategies TakeWhile & SkipWhile: Dynamic partitioning
5. Sets & Lookups
Union, Intersect, Except: Set theory in C# Zip: Combining two streams ToDictionary vs ToLookup: One-to-One vs One-to-Many Chunk: Slicing data for batch processing
6. Join & Grouping
Inner Join: The standard match GroupJoin: Creating hierarchical results GroupBy: The SQL counterpart in LINQ Left Outer Join: The manual workaround in LINQ
7. Advanced Providers & Parallelism
PLINQ (Parallel LINQ): Speeding up CPU-bound queries AsParallel vs AsSequential: When to switch LINQ to XML: Processing documents with ease Custom LINQ Providers: How to build your own 'Queryable'
8. Real-world Performance & Patterns
Memory Leaks in LINQ: Capturing variables and closures Architect Case Study: Optimizing a multi-join dashboard query