加入收藏 | 设为首页 | 会员中心 | 我要投稿 李大同 (https://www.lidatong.com.cn/)- 科技、建站、经验、云计算、5G、大数据,站长网!
当前位置: 首页 > 百科 > 正文

c# – 将Delegate对象传递给带有Func <>参数的方法

发布时间:2020-12-15 23:53:22 所属栏目:百科 来源:网络整理
导读:我有一个方法Foo4接受类型为Func的参数.如果我传递一个匿名类型的参数,我没有错误.但是,如果我创建并传递一个引用具有正确签名的Method的“委托”类型的对象,则会出现编译器错误.在这种情况下,我无法理解为什么我会收到错误. class Learn6 { delegate string
我有一个方法Foo4接受类型为Func<>的参数.如果我传递一个匿名类型的参数,我没有错误.但是,如果我创建并传递一个引用具有正确签名的Method的“委托”类型的对象,则会出现编译器错误.在这种情况下,我无法理解为什么我会收到错误.

class Learn6
    {
        delegate string Mydelegate(int a);
        public void Start()
        {
            Mydelegate objMydelegate = new Mydelegate(Foo1);

            //No Error
            Foo4(delegate(int s) { return s.ToString(); });

            //This line gives compiler error.
            Foo4(objMydelegate);

        }

        public string Foo1(int a) { return a.ToString();}



        public void Foo4(Func<int,string> F) { Console.WriteLine(F(42)); }
    }

解决方法

如果直接传递对方法的引用,它可以工作:

Foo4(Foo1);

这是因为具有相同形状的实际代表本身并不被认为是兼容的.如果合同是隐式的,编译器会推断合同并将其匹配.如果它们是显式的(例如声明的类型),则不执行推理 – 它们只是不同的类型.

它类似于:

public class Foo
{
    public string Property {get;set;}
}

public class Bar
{
    public string Property {get;set;}
}

我们可以看到这两个类具有相同的签名并且是“兼容的”,但编译器将它们视为两种不同的类型,仅此而已.

(编辑:李大同)

【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容!

    推荐文章
      热点阅读