现在的位置: 首页 > 综合 > 正文

继承Object和ContextBoundObject处理效率上的差距

2011年07月29日 ⁄ 综合 ⁄ 共 1212字 ⁄ 字号 评论关闭

       ContextBoundObject一个很熟悉的对象,它提供对象有处理上下文的能力;通过它能够方便地实现AOP处理机制。它带来好处的同时也会带来效率上的损失,到底继承ContextBoundObject后会在效率上损失多少呢?下面用简单的代码测试一下;测试方法很简单就是建立两个具有相同方法的对象,一个继承于ContextBoundObject一个没有;然后分别循环次数地执行对象的创建和方法调用(以下测试代码并不能完全反映所有应用情况)。

测试代码

                System.Diagnostics.Stopwatch stop = new System.Diagnostics.Stopwatch();

                stop.Reset();

                stop.Start();

                for (int i = 0; i < 10000; i++)

                {

                    Class1 cl1 = new Class1();

                    cl1.Add();

                }

                stop.Stop();

                Console.WriteLine(stop.ElapsedTicks);

 

                stop.Reset();

                stop.Start();

                for (int i = 0; i < 10000; i++)

                {

                    Class2 cl2 = new Class2();

                    cl2.Add();

                }

                stop.Stop();

                Console.WriteLine(stop.ElapsedTicks);

类定义代码

    public class Class1

    {

        public void Add()

        {

        }

    }

    public class Class2 : ContextBoundObject

    {

        public void Add()

        {

        }

    }

测试结果

Class1处理花的时间:22555(1/100毫微秒)

Class2处理花的时间:4747008(1/100毫微秒)

 

从测试结构可以看到,继承ContextBoundObject在处理效率上损失还是很利害的。但实际开发过程可以根据情况使用(开发方便性和执行效率总是很难取得平衡)。ContextBoundObject得到的方便性类似于反射的机制,但滥用同样有可能导致严重的后果。

抱歉!评论已关闭.