Mastering Expression Trees With .NET Reflector
Following my last post, I received lots of enquiries about how got to master the creation of expression trees.
The answer is: .NET Reflector
On that post I needed to to generate an expression tree for this expression:
Expression<Func<object, object>> expression = o => ((object)((SomeType)o).Property1);
I just compiled that code in Visual Studio 2010, loaded the assembly in .NET Reflector, and disassembled it to C# without optimizations (View –> Options –> Disassembler –> Optimization: None).
The disassembled code looked like this:
Expression<Func<object, object>> expression; ParameterExpression CS$0$0000; ParameterExpression[] CS$0$0001; expression = Expression.Lambda<Func<object, object>>(Expression.Convert(Expression.Property(Expression.Convert(CS$0$0000 = Expression.Parameter(typeof(object), "o"), typeof(SomeType)), (MethodInfo) methodof(SomeType.get_Property1)), typeof(object)), new ParameterExpression[] { CS$0$0000 });
After giving valid C# names to the variables and tidy up the code a bit, I came up with this:
ParameterExpression parameter = Expression.Parameter(typeof(object), "o"); Expression<Func<object, object>> expression = Expression.Lambda<Func<object, object>>( Expression.Convert( Expression.Property( Expression.Convert( parameter, typeof(SomeType) ), "Property1" ), typeof(object) ), parameter );
Easy! Isn’t it?