基于nutz框架理解Ioc容器

同样我们从问题入手去验证以及去理解Ioc容器都做了哪些事情:
1.nutz是有几种方式获取需要容器管理bean的信息?
       第一种是使用json格式的文件进行配置,如:
       

       第二种:使用注解@IocBean
              

       第三种:使用xml
                     略.......
2. 如何那么多的方式如何进行选择呢?
      我们自己实际的生产环境的用法是:
      一般的依赖关系都是固定的,在运行的时候基本不变的,我们采用的是注解,
      将可能变动的关系写到配置文件里。
      比如:我们将项目中各个分层之间的service采用的是注解,
                  

                将数据库相关配置放到配置文件中,
                

3.ioc容器是如何确定哪些Bean是容器需要管理的:
   问几个问题:
    a.它是怎么知道哪些文件中配置是需要被容器管理的bean,以及需要扫描哪些类上的@IocBean注解呢??
              nutz提供了一个注解(@IocBy)专门用于在主模块类上指定扫描哪些文件以及注解。
              

              有上图可以知道:
              json方式配置的bean的加载器去webconfig/下,以及Linux下的两个路径下扫描。
              注解方式配置的bean加载器将扫描com.uxuexi开头包下的类。
    b.它是如何去扫描除本项目之外的jar包(一般都是自己创建的,不会扫描第三方)呢?
              可以在项目启动的时候,nutz的ioc容器加载完毕之前手动将要容器管理的bean扫描到容器中。            

4. 何时开始创建这些被容器管理的bean?
           nutz在服务启动的时候将所有被@IocBean注解的类以及配置在json格式文件中的类信息加载到一个map中。
            

           就是上面圈住的那个map,其中key默认是这个类名。
           而这个IocObject这个类主要就是记住这个类的信息:
          

          就是说在服务器启动的时候nutz只是扫描注解和文件将需要被容器管理的bean的信息集中存储到一个地方中,并没有真正的创建这些bean的实例。
5.容器什么时候会创建真正bean的实例??
           分两种种情况:
             1.第一种当服务启动的时候就需要获取容器中的bean实例,可以手动获取容器。
                    

              2.第二种是当我们的第一次http请求映射到的那个Module类,nutz会帮你去从ioc容器中取。
                     

6.都提供哪些Ioc的注入类型??
          构造函数注入:
                     

          属性注入:
                 

7.ioc容器在什么时候销毁???
       nutz通过将Filter的destroy方法在web容器停止运行的时候会将ioc容器销毁,
        

       NutzLoading类中的方法:
       

       就是将缓存中存放map清空。
 

 



 

posted @ 2015-11-23 18:52  王森  阅读(4265)  评论(0编辑  收藏  举报