我想知道这是否可能,因为我 5 分钟的实验证明是徒劳的。
我希望它会像这样简单:
T Identity<T>(T t) { return t; }
但这无法在采用 Func 参数的泛型方法上编译。例如 OrderBy。即使指定类型参数(这正是我想要避免的!),它也无法编译。
接下来我尝试了一些我认为可行的方法:
Func<T, R> MakeIdentity<T, R>()
{
return (T t) => (R)(object)t;
}
也不行:((这在应用类型参数时编译,再次,不是我想要的)
有没有人有幸做出这样的事情?
更新:请不要说:x => x,我知道,这很明显!我要的是一个函数,而不是一个表达式:)
更新2:当我提到身份时,我的意思是在功能意义上,函数只是返回您传递给它的相同对象。它可能在我遇到的每一种功能语言中都有,但那些不使用静态类型。我想知道如何使用泛型来做到这一点(如果可能的话)。只是为了好玩!
更新3:这是基于第二个想法的部分“解决方案”:
Expression<Func<T, T>> MakeIdentity<T>()
{
return t => t;
}
void Foo(string[] args)
{
var qargs = args.AsQueryable();
var q = qargs.OrderBy(MakeIdentity<string>());
...
}
我认为除此之外没有任何可能。