11

我想知道这是否可能,因为我 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>());
  ...
}

我认为除此之外没有任何可能。

4

4 回答 4

3

类型推断将不起作用,因为主机方法和输入法都是通用的。为此,您必须编写

myList.OrderBy<int, int>(Identity);

或者

myList.OrderBy((Func<int, int>)Identity);
于 2009-02-19T15:53:56.293 回答
2

这适用于我到目前为止需要它的地方。

internal class IdentityFunction<TSource>
{
    public static Func<TSource, TSource> Instance
    {
        get { return x => x; }
    }
}

OrderBy(IdentityFunction<Foo>.Instance)
于 2015-12-01T19:21:09.483 回答
1

您遇到的问题是 C# 中的匿名函数和方法组不参与类型推断。必须给出显式类型。

您可以做的是为匿名函数提供身份函数。例子

Func<T> IdentityFunc1<T>(Func<T> func) { return func; }

我不完全确定您对第二个样本的了解。你能详细说明吗?

于 2009-02-19T15:19:48.137 回答
0

第一个选项对我有用:

public class Foo {

   public Foo(Func<MyObj, MyObj> map) {... }

}

public class Client {

   private static T Identity<T>(T t) { return t; }

   public void main() {
      var foo = new Foo(Identity);

      var c = from f in Enumerable.Range(0, 100) select Identity(f);
      c.ToList().ForEach(System.Console.Out.WriteLine);
   }
}
于 2010-11-23T07:53:32.683 回答