c# - 分配给委托(delegate)时的返回值和签名歧义——Func<Task> vs Action

标签 c# return task overloading signatures

我惊讶地发现,在将方法传递给另一个方法时,方法的返回类型会产生重载歧义。由于返回类型不是签名的一部分,因此很难看出更改返回值会如何在以前不存在的地方产生歧义。然而,void 和 Task 似乎就是这种情况。考虑以下几点:

    class Signature
    {
        static public void Overload(Func<Task> countasync)
        {
        }
        static public void Overload(Action count)
        {
        }
    }

    void Decrement() { }
    Task IncrementAsync() { return Task.CompletedTask; }

    void TestSig()
    {
        Signature.Overload(this.IncrementAsync); // no compile time error
        Signature.Overload(this.Decrement); // compile time error: this call is ambiguous 
    }

有没有一种方法可以定义 Overload 参数类型,以便第二次调用不会产生歧义,同时仍允许第一次调用?

最佳答案

不,没有办法修复重载决议。

但是,您可以以稍微丑陋的调用站点代码为代价来消除歧义:

Signature.Overload( () => this.Decrement() );

在这种情况下,编译器将正确地推断出重载。

关于c# - 分配给委托(delegate)时的返回值和签名歧义——Func<Task> vs Action,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/42184136/

相关文章:

java - 如何读取文件并返回字符串及其值

c# - 将 EAP 包装在任务中

c# - MySqlDataReader 关闭连接

c# - LINQ2SQL 和 NHibernate,按计算列分组

python - 探测 python 函数

clojure - 在 Clojure 中如何从函数早期返回?

multithreading - JavaFX2 : Can I pause a background Task/Service?

c# - 事件完成的任务

c# - 对 C# 循环中的多线程感到困惑

c# - 为什么甚至可以更改私有(private)成员,或者使用反射在 C# 中运行私有(private)方法?