栏目分类:
子分类:
返回
名师互学网用户登录
快速导航关闭
当前搜索
当前分类
子分类
实用工具
热门搜索
名师互学网 > IT > 面试经验 > 面试问答

调用代表与方法的性能

面试问答 更新时间: 发布时间: IT归档 最新发布 模块sitemap 名妆网 法律咨询 聚返吧 英语巴士网 伯小乐 网商动力

调用代表与方法的性能

我还没有看到这种效果-我当然从来没有遇到过瓶颈。

这是一个非常粗糙的基准,它(无论如何在我的盒子上)显示了委托实际上比接口要

using System;using System.Diagnostics;interface IFoo{    int Foo(int x);}class Program : IFoo{    const int Iterations = 1000000000;    public int Foo(int x)    {        return x * 3;    }    static void Main(string[] args)    {        int x = 3;        IFoo ifoo = new Program();        Func<int, int> del = ifoo.Foo;        // Make sure everything's JITted:        ifoo.Foo(3);        del(3);        Stopwatch sw = Stopwatch.StartNew();     for (int i = 0; i < Iterations; i++)        { x = ifoo.Foo(x);        }        sw.Stop();        Console.WriteLine("Interface: {0}", sw.ElapsedMilliseconds);        x = 3;        sw = Stopwatch.StartNew();     for (int i = 0; i < Iterations; i++)        { x = del(x);        }        sw.Stop();        Console.WriteLine("Delegate: {0}", sw.ElapsedMilliseconds);    }}

结果(.NET 3.5; .NET 4.0b2大致相同):

Interface: 5068Delegate: 4404

现在我没有特别的信念,这意味着委托 确实
比接口要快…但是这让我相当确信,委托不会比接口慢一个数量级。此外,这在委托/接口方法中几乎不执行任何操作。显然,随着每次调用越来越多的工作,调用成本将变得越来越少。

要注意的一件事是,您不会多次创建新的委托,而只使用一个接口实例。这 可能
会引起问题,因为它会引发垃圾回收等。如果您在循环内使用实例方法作为委托,则发现在循环外声明委托变量,创建单个委托实例并重用会更有效。它。例如:

Func<int, int> del = myInstance.MyMethod;for (int i = 0; i < 100000; i++){    MethodTakingFunc(del);}

效率比:

for (int i = 0; i < 100000; i++){    MethodTakingFunc(myInstance.MyMethod);}

难道这就是您所看到的问题?



转载请注明:文章转载自 www.mshxw.com
本文地址:https://www.mshxw.com/it/495429.html
我们一直用心在做
关于我们 文章归档 网站地图 联系我们

版权所有 (c)2021-2022 MSHXW.COM

ICP备案号:晋ICP备2021003244-6号