Since you are trying to avoid reflection overhead, but are dealing with expression trees, I assume that you are trying to compile an expression for the delegate to set the property.
- . - .NET 3.5, Expression.Call. :
class Test{ public int X {get;set;} }
var xPropSetter = typeof(Test)
.GetProperty("X",BindingFlags.Instance|BindingFlags.Public)
.GetSetMethod();
var newValPar=Expression.Parameter(typeof(int));
var objectPar=Expression.Parameter(typeof(Test));
var callExpr=Expression.Call(objectPar, xPropSetter, newValPar);
var setterAction = (Action<Test,int>)
Expression.Lambda(callExpr, objectPar, newValPar).Compile();
Test val = new Test();
Console.WriteLine(val.X);
setterLambda(val,42);
Console.WriteLine(val.X);
, , , , :
var setterAction = (Action<Test,int>)
Delegate.CreateDelegate(typeof(Action<Test,int>), xPropSetter);