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

c# – 代理实例和方法指针有什么区别?

发布时间:2020-12-15 04:35:09 所属栏目:百科 来源:网络整理
导读:我认为一个委托实例可以与函数实例互换. 采取以下代码: delegate int AddDelegate(int a,int b);AddDelegate DelegateInstance;public void DoStuff(){ //I can call this without a delegate "instance": MethodThatTakesAdd(Add); //I can also call it W
我认为一个委托实例可以与函数实例互换.

采取以下代码:

delegate int AddDelegate(int a,int b);

AddDelegate DelegateInstance;

public void DoStuff()
{
    //I can call this without a delegate "instance":
    MethodThatTakesAdd(Add);

    //I can also call it WITH a delegate "instance"
    DelegateInstance = Add;
    MethodThatTakesAdd(DelegateInstance);
}

public int Add(int a,int b)
{
    return a + b;
}

public void MethodThatTakesAdd(AddDelegate addFunction)
{
    Console.WriteLine(addFunction(1,2).ToString());
}

调用它的两种方法都是等同的,如果你只使用C#,你将永远不会看到差异(至少我还没有达到这一点).但是,最近我是一个非托管代码,正在调用这个托管代码,它们被不同的对待.例如,在一种情况下,如果我将函数直接用作回调(即使我的对象实例被保留),我将收到错误“回收一个垃圾收集的委托”.使用“委托实例”来解决问题.

那里有人知道有什么区别吗?

解决方法

术语分析:代替方法指针,更合适的术语是方法组.

在功能方面,这两个语句是等效的.那就是它们产生几乎相同的IL.区别在于代理值的存储位置.

在第一种情况下,您直接通过方法组添加到MethodThatTakesAdd.这将导致临时委托值被创建,然后传递给MethodThatTakesAdd.当代码值不存在时,MethodThatTakesAdd返回的代码值将受到垃圾回收.

在第二种情况下,您将委托分配给外部实例上的字段.这通常会增加代表的使用寿命,从而减少在您的忙碌呼叫期间垃圾回收的机会.

(编辑:李大同)

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

    推荐文章
      热点阅读