2009-05-13 9 views
7

エラーメッセージは、 "型または名前空間の名前 'T'が見つかりませんでした。ネストされた汎用式を返す<Func <T, bool>>

???

public static Expression<Func<T, bool>> MakeFilter(string prop, object val) 
{ 
    ParameterExpression pe = Expression.Parameter(typeof(T), "p"); 
    PropertyInfo pi = typeof(T).GetProperty(prop); 
    MemberExpression me = Expression.MakeMemberAccess(pe, pi); 
    ConstantExpression ce = Expression.Constant(val); 
    BinaryExpression be = Expression.Equal(me, ce); 
    return Expression.Lambda<Func<T, bool>>(be, pe); 
} 

関連リンク:

Using reflection to address a Linqed property

http://social.msdn.microsoft.com/forums/en-US/linqprojectgeneral/thread/df9dba6e-4615-478d-9d8a-9fd80c941ea2/

Runtime creation of generic Func<T>

答えて

10

あなたはこの方法自体は汎用的にする必要があります。

public static Expression<Func<T, bool>> MakeFilter<T>(string prop, object val) 
                -+- 
               ^
                +- this 
3

あなたの方法に定義された一般的な引数はありません。あなたは1(MakeFilter<T>)を定義する必要があります

public static Expression<Func<T, bool>> MakeFilter<T>(string prop, object val) 
{ 
    ParameterExpression pe = Expression.Parameter(typeof(T), "p"); 
    PropertyInfo pi = typeof(T).GetProperty(prop); 
    MemberExpression me = Expression.MakeMemberAccess(pe, pi); 
    ConstantExpression ce = Expression.Constant(val); 
    BinaryExpression be = Expression.Equal(me, ce); 
    return Expression.Lambda<Func<T, bool>>(be, pe); 
} 
2

方法は、(MakeFilter<T>)ジェネリックとして宣言する必要があります

public static Expression<Func<T, bool>> MakeFilter<T>(string prop, object val) 

そうでない場合は、どのように他の発信者はTが何であるかを指定することができるだろうか?

関連する問題