Autofac下载地址:http://code.google.com/p/autofac/

Castle Windsor下载地址:http://sourceforge.net/projects/castleproject/files/Windsor/2.5/Castle.Windsor.2.5.3.zip/download

Unity下载地址:http://entlib.codeplex.com/

Spring.NET下载地址:http://www.springframework.net/

StructureMap下载地址:http://sourceforge.net/projects/structuremap/files/

Ninject下载地址:http://ninject.org/download

其中,测试程序均采用最新的类库。

基础工作

1、程序还是引用上一篇的示例作为测试背景。

2、编写一个性能计数器,这里我采用老赵写的一个CodeTimer的类,具体介绍见:http://www.cnblogs.com/JeffreyZhao/archive/2009/03/10/codetimer.html

使用方式类似于:

int iteration = 100 * 1000;string s = ""; 
CodeTimer.Time("String Concat", iteration, () => { s += "a"; }); 
StringBuilder sb = new StringBuilder(); 
CodeTimer.Time("StringBuilder", iteration, () => { sb.Append("a"); });

3、编写一个IRunner运行接口:

public interface IRunner 

    void Start(RunType runType); 
}

以及RunnerBase抽象基础运行类:


public abstract class RunnerBase 

    private int _iteration = Convert.ToInt32(System.Configuration.ConfigurationSettings.AppSettings["Iteration"] ?? "10000"); 
    internal int Iteration 
    { 
        get { return _iteration; } 
    }     internal void Time(Action action) 
    { 
        CodeTimer.Time(Name, Iteration, action); 
    }     protected abstract string Name { get; } 

这里_iteration表示测试运行次数,通过配置文件来设置值。Time方法通过计数器对action方法进行Iteration次迭代。

编写一个RunManager的运行管理器:


public class RunManager 

    public static void Start(IRunner runner) 
    { 
        Start(runner, RunType.Transient); 
    }     public static void Start(IRunner runner, RunType runType) 
    { 
        runner.Start(runType); 
    } 
}

在测试中,我采用两种方式的性能比较,一个是单例状态,一个是非单例状态:


/// <summary> 
/// 运行状态 
/// </summary> 
public enum RunType 

    /// <summary> 
    /// 单例 
    /// </summary> 
    Singleton,     /// <summary> 
    /// 瞬时 
    /// </summary> 
    Transient 

好了,现在我的程序只要继承RunnerBase以及IRunnre接口,就可以实现各个IOC框架的初始化装配的工作了。基础工作已经做好。

各个IOC框架测试程序

1、Autofac


public class AutofacRunner : RunnerBase, IRunner 

    protected override string Name 
    { 
        get { return "Autofac"; } 
    }     public void Start(RunType runType) 
    { 
        var builder = new ContainerBuilder();         //if (runType == RunType.Singleton) 
        //    builder.RegisterType<DatabaseManager>().SingleInstance(); 
        //else 
        //    builder.RegisterType<DatabaseManager>(); 
        //builder.RegisterType<SqlDatabase>().As<IDatabase>(); 
        ////builder.RegisterModule(new ConfigurationSettingsReader("autofac"));         builder.RegisterType<SqlDatabase>().As<IDatabase>(); 
        if (runType == RunType.Singleton) 
            builder.Register(c => new DatabaseManager(c.Resolve<IDatabase>())).SingleInstance(); 
        else 
            builder.Register(c => new DatabaseManager(c.Resolve<IDatabase>()));           var container = builder.Build();         Time(() => 
        { 
            var manager = container.Resolve<DatabaseManager>(); 
            manager.Search("SELECT * FROM USER"); 
        });         container.Dispose(); 
    } 

2、Castle Windsor


public class WindsorRunner : RunnerBase, IRunner 

    protected override string Name 
    { 
        get { return "Castle Windsor"; } 
    }     public void Start(RunType runType) 
    { 
        var container = new WindsorContainer(); 
        if(runType == RunType.Singleton) 
            container.Register(Component.For(typeof(DatabaseManager)).LifeStyle.Singleton); 
        else 
            container.Register(Component.For(typeof(DatabaseManager)).LifeStyle.Transient);         container.Register(Component.For(typeof(IDatabase)).ImplementedBy(typeof(SqlDatabase)));         Time(() => 
        { 
            var manager = container.Resolve<DatabaseManager>(); 
            manager.Search("SELECT * FROM USER"); 
        }); 
    } 

3、Unity


public class UnityRunner : RunnerBase, IRunner 

    protected override string Name 
    { 
        get { return "Unity"; } 
    }     public void Start(RunType runType) 
    { 
        var container = new UnityContainer(); 
        if(runType == RunType.Singleton) 
            container.RegisterType<DatabaseManager>(new ContainerControlledLifetimeManager()); 
        else 
            container.RegisterType<DatabaseManager>(new TransientLifetimeManager()); 
        container.RegisterType<IDatabase, SqlDatabase>();         Time(() => 
            { 
                var manager = container.Resolve<DatabaseManager>(); 
                manager.Search("SELECT * FROM USER"); 
            }); 
    } 

4、Spring.NET


public class SpringRunner : RunnerBase, IRunner 

    protected override string Name 
    { 
        get { return "Spring.NET"; } 
    }     public void Start(RunType runType) 
    { 
        string databaseManagerName; 
        if (runType == RunType.Singleton) 
            databaseManagerName = "DatabaseManager_Singleton"; 
        else 
            databaseManagerName = "DatabaseManager_Transient";         Time(() => 
        { 
            IApplicationContext context = ContextRegistry.GetContext(); 
            var manager = (DatabaseManager)context.GetObject(databaseManagerName); 
            manager.Search("SELECT * FROM USER"); 
        }); 
    } 

5、StructureMap


public class StructureMapRunner : RunnerBase, IRunner 

    protected override string Name 
    { 
        get { return "StructureMap"; } 
    }     public void Start(RunType runType) 
    { 
        ObjectFactory.Initialize(container => 
        { 
            if (runType == RunType.Singleton) 
                container.ForRequestedType<DatabaseManager>().Singleton(); 
            else 
                container.ForRequestedType<DatabaseManager>(); 
            container.ForRequestedType<IDatabase>().TheDefaultIsConcreteType<SqlDatabase>(); 
        });         Time(() => 
            { 
                var manager = ObjectFactory.GetInstance<DatabaseManager>(); 
                manager.Search("SELECT * FROM USER"); 
            }); 
    } 

6、Ninject


public class NinjectRunner : RunnerBase, IRunner 

    protected override string Name 
    { 
        get { return "Ninject"; } 
    }     public void Start(RunType runType) 
    { 
        IKernel kernel = new StandardKernel(new MyNinjectModule(runType));         Time(() => 
        { 
            var manager = kernel.Get<DatabaseManager>(); 
            manager.Search("SELECT * FROM USER"); 
        }); 
    } 

客户端测试程序


static void Main(string[] args) 

    CodeTimer.Initialize();     Console.WriteLine("IOC - Singleton"); 
    // Autofac Singleton 
    RunManager.Start(new AutofacRunner(), RunType.Singleton);        
    // Castle Windsor 
    RunManager.Start(new WindsorRunner(), RunType.Singleton); 
    // Unity 
    RunManager.Start(new UnityRunner(), RunType.Singleton); 
    // Spring.NET 
    RunManager.Start(new SpringRunner(), RunType.Singleton); 
    // StructureMap 
    RunManager.Start(new StructureMapRunner(), RunType.Singleton); 
    // Ninject 
    RunManager.Start(new NinjectRunner(), RunType.Singleton);     Console.WriteLine("==================================="); 
    Console.WriteLine("IOC - Transient"); 
    // Autofac Singleton 
    RunManager.Start(new AutofacRunner(), RunType.Transient); 
    // Castle Windsor 
    RunManager.Start(new WindsorRunner(), RunType.Transient); 
    // Unity 
    RunManager.Start(new UnityRunner(), RunType.Transient); 
    // Spring.NET 
    RunManager.Start(new SpringRunner(), RunType.Transient); 
    // StructureMap 
    RunManager.Start(new StructureMapRunner(), RunType.Transient); 
    // Ninject 
    RunManager.Start(new NinjectRunner(), RunType.Transient);     Console.ReadKey(); 

通过修改App.config的Iteration配置值,来设置迭代次数。

<appSettings> 
  <add key="Iteration" value="100000" /> 
</appSettings> 

运行结果

1、Iteration=1000:

分析:在千数量级时,Autofac,CastleWindsor、StructureMap基本差不多,效率上比其他的要高。

2、Iteration=10000:

分析:在万数量级时,Autofac,CastleWindsor,StructureMap基本效率还是差不多,其中StructureMap效率稍稍有些下降;Spring.NET以及Ninject的性能比较低。

3、Iteration=100000:

分析:在十万数量级时,CastleWindsor的效率开始下降,而在Transient方面,StructureMap和Autofac基本差不多。

4、Iteration=1000000:

分析:在百万数量级时,Autofac和StructureMap两者还是保持比较高的效率,并且在Transient方面,StructureMap已经超过了Autofac。

总结:从测试中,可以看出Autofac和StructureMap在性能上面还是体现出比较大的优势,Ninject可以说性能上较低。而Spring.NET不仅仅专注于IOC方面,它还专注于其他方方面面的功能,所以在IOC方面的性能不是太高。另外,微软的Unity中规中矩,性能较为稳定,也是一个不错的选择。另外,可能测试程序会有所偏差,希望大家也能够指出问题!

各大主流.Net的IOC框架性能测试比较的更多相关文章

  1. 各大主流.Net的IOC框架性能测试比较(转)

    出处:http://www.cnblogs.com/liping13599168/archive/2011/07/17/2108734.html 在上一篇中,我简单介绍了下Autofac的使用,有人希 ...

  2. 各大主流.Net的IOC框架

    Autofac下载地址:http://code.google.com/p/autofac/ Castle Windsor下载地址:http://sourceforge.net/projects/cas ...

  3. 主流IOC框架测验(.NET)

    上一篇中,我简单介绍了下Autofac的使用,有人希望能有个性能上的测试,考虑到有那么多的IOC框架,而主流的有:Castle Windsor.微软企业库中的Unity.Spring.NET.Stru ...

  4. 6 大主流 Web 框架优缺点对比:15篇前端热文回看

    摘自:http://blog.csdn.net/VhWfR2u02Q/article/details/78993079 注:以下文章,点击标题即可阅读 <6 大主流 Web 框架优缺点对比> ...

  5. IOC框架

    一. IOC理论的背景 我们都知道,在采用面向对象方法设计的软件系统中,它的底层实现都是由N个对象组成的,所有的对象通过彼此的合作,最终实现系统的业务逻辑. 图1:软件系统中耦合的对象 如果我们打开机 ...

  6. 转:IOC框架

    CSND上看了王泽滨的博客关于IOC的,觉得说的很透彻,地址为:http://blog.csdn.net/wanghao72214/article/details/3969594 1 IoC理论的背景 ...

  7. IoC框架(转载)

      1 IoC理论的背景    我们都知道,在采用面向对象方法设计的软件系统中,它的底层实现都是由N个对象组成的,所有的对象通过彼此的合作,最终实现系统的业务逻辑.  图1:软件系统中耦合的对象 如果 ...

  8. IOC框架的认识

    转:http://blog.csdn.net/wanghao72214/article/details/3969594 1 IoC理论的背景 我们都知道,在采用面向对象方法设计的软件系统中,它的底层实 ...

  9. IoC框架---通俗概述

    1 IoC理论的背景    我们都知道,在采用面向对象方法设计的软件系统中,它的底层实现都是由N个对象组成的,所有的对象通过彼此的合作,最终实现系统的业务逻辑.  图1:软件系统中耦合的对象 如果我们 ...

随机推荐

  1. 烂泥:Postfix邮件服务器搭建之准备工作

    说实话,Postfix邮件服务器的搭建是一件很麻烦的事情,需要各种软件之间的配置和调试.在写这篇文章之前,我也是搭建测试了不下于10次才算把整个流程给走通,今天刚好有时间把整个搭建过程记录下来. 在正 ...

  2. eclipse svn分支与合并操作

    以前做项目的时候没有用过svn的分支合并操作,今天用到了,刚开始还真不会啊.最后查了下就是这么的方便.专门记录下来. 原文来自:http://blog.csdn.net/lisq037/article ...

  3. ASP.NET SignalR

    何为ASP.NET SignalR,有什么用 ASP.NET SignalR是一个ASP.NET库,是为了实现实时web通信而创造的,能让服务器与客户端实现即时通信,而不需要服务器等待接收到客户端请求 ...

  4. [HTML表格]在databases显示行的附加信息

    模板代码: <!-- DataTables CSS --> <link rel="stylesheet" href="{% static 'DataTa ...

  5. 一张图看懂ANSYS17.0 流体 新功能与改进

    一张图看懂ANSYS17.0 流体 新功能与改进   提交 我的留言 加载中 已留言   一张图看懂ANSYS17.0 流体 新功能与改进 原创2016-02-03ANSYS模拟在线模拟在线 模拟在线 ...

  6. 开放api接口签名验证

    不要急,源代码分享在最底部,先问大家一个问题,你在写开放的API接口时是如何保证数据的安全性的?先来看看有哪些安全性问题在开放的api接口中,我们通过http Post或者Get方式请求服务器的时候, ...

  7. 第24章 java线程(3)-线程的生命周期

    java线程(3)-线程的生命周期 1.两种生命周期流转图 ** 生命周期:**一个事物冲从出生的那一刻开始到最终死亡中间的过程 在事物的漫长的生命周期过程中,总会经历不同的状态(婴儿状态/青少年状态 ...

  8. inverse

    首先术语inverse 被翻译为反转的意思.inverse 制定了关联关系中的方向. 当set的inverse属性默认情况下,hibernate会按照持久化对象的属性变化来同步更新数据库. 得到两条s ...

  9. @RenderBody、@RenderSection、@RenderPage、Html.RenderPartial、Html.RenderAction的作用和区别

    1. RenderBody在Razor引擎中没有了“母版页”,取而代之的是叫做“布局”的页面(_Layout.cshtml)放在了共享视图文件夹中.在这个页面中,会看到标签里有这样一条语句:@Rend ...

  10. Servlet容器Tomcat中web.xml中url-pattern的配置详解[附带源码分析]

    目录 前言 现象 源码分析 实战例子 总结 参考资料 前言 今天研究了一下tomcat上web.xml配置文件中url-pattern的问题. 这个问题其实毕业前就困扰着我,当时忙于找工作. 找到工作 ...