激情久久久_欧美视频区_成人av免费_不卡视频一二三区_欧美精品在欧美一区二区少妇_欧美一区二区三区的

服務(wù)器之家:專注于服務(wù)器技術(shù)及軟件下載分享
分類導(dǎo)航

PHP教程|ASP.NET教程|Java教程|ASP教程|編程技術(shù)|正則表達(dá)式|C/C++|IOS|C#|Swift|Android|VB|R語言|JavaScript|易語言|vb.net|

服務(wù)器之家 - 編程語言 - Java教程 - Spring框架初始化解析

Spring框架初始化解析

2021-02-21 11:56江曉曼軟件園 Java教程

這篇文章主要介紹了Spring框架初始化解析,具有一定參考價值,需要的朋友可以了解下。

一、Spring能做什么?

Spring的主要目的是使J2EE易用和促進(jìn)好編程習(xí)慣。

倒置控制容器 Spring的設(shè)計核心是 org.springframework.beans 包, 為與JavaBeans一起工作而設(shè)計。 這個包一般不直接被用戶使用, 但作為基礎(chǔ)為更多的其他功能服務(wù). 下一個較高層面的抽象是"Bean Factory"。 Spring bean factory 是一個普通的Factory,它使對象能夠按名稱獲取,并且能管理對象之間的關(guān)系。 Bean factories 支持兩種對象模式: . Singleton:在此模式中,有一個具有特定名稱的共享對象實例,它在查找時被獲取。這是默認(rèn)的,而且是最為經(jīng)常使用的。它對于無狀態(tài)對象是一種理想的模式。 .Prototype:在此模式中,每次獲取將創(chuàng)建一個獨立的對象。

二、spring啟動加載及實現(xiàn)方式

第一種:通過注解@PostConstruct 和 @PreDestroy 方法 實現(xiàn)初始化和銷毀bean之前進(jìn)行的操作

第二種:通過 在xml中定義init-method 和 destory-method方法

第三種:通過bean實現(xiàn)InitializingBean和 DisposableBean接口

第四種:寫一個類,實現(xiàn)BeanPostProcessor接口,這個接口有兩個方法。

(1):postProcessBeforeInitialization方法,在spring中定義的bean初始化前調(diào)用這個方法
(2):postProcessAfterInitialization方法,在spring中定義的bean初始化后調(diào)用這個方法
或?qū)崿F(xiàn)
InstantiationAwareBeanPostProcessor,是BeanPostProcessor的子接口
Spring 容器加載完成后執(zhí)行

從spring監(jiān)聽器作為入口。

org.springframework.web.context.ContextLoaderListener

找到初始化spring的方法

?
1
2
3
4
5
6
7
/**
   * Initialize the root web application context.
   */
  @Override
  public void contextInitialized(ServletContextEvent event) {
    initWebApplicationContext(event.getServletContext());
  }

進(jìn)入initWebApplicationContext 方法

?
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
if (this.context == null) {
  this.context = createWebApplicationContext(servletContext);
}
if (this.context instanceof ConfigurableWebApplicationContext) {
  ConfigurableWebApplicationContext cwac = (ConfigurableWebApplicationContext) this.context;
  if (!cwac.isActive()) {
    // The context has not yet been refreshed -> provide services such as
    // setting the parent context, setting the application context id, etc
    if (cwac.getParent() == null) {
      // The context instance was injected without an explicit parent ->
      // determine parent for root web application context, if any.
      ApplicationContext parent = loadParentContext(servletContext);
      cwac.setParent(parent);
    }
    configureAndRefreshWebApplicationContext(cwac, servletContext);
  }
}

ApplicationListener

1、編寫一個實現(xiàn)ApplicationListener的listener類,

?
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
import org.springframework.context.ApplicationListener;
import org.springframework.context.event.ContextRefreshedEvent;
import org.springframework.stereotype.Service;
@Service
public class StartupListenerimplements
 ApplicationListener<ContextRefreshedEvent>
{
  @Override
  public void onApplicationEvent(ContextRefreshedEvent event)
  {
    if(event.getApplicationContext().getParent() == null)//root application context 沒有parent,他就是老大.
    {
      //需要執(zhí)行的邏輯代碼,當(dāng)spring容器初始化完成后就會執(zhí)行該方法。
      System.out.println("\n\n\n\n\n______________\n\n\n加載了\n\n_________\n\n");
    }
    
    //或者下面這種方式
    if(event.getApplicationContext().getDisplayName().equals("Root WebApplicationContext"))
    {
      System.out.println("\n\n\n_________\n\n加載一次的 \n\n ________\n\n\n\n");
    }
    
  }
}

2、在配置文件(applicationContext-servlet.xml)中設(shè)置Service掃描的包

?
1
2
3
4
5
<!-- 注冊@Controller 、@Service-->
  <context:component-scan base-package="com.test.controller" use-default-filters="false">
    <context:include-filter type="annotation" expression="org.springframework.stereotype.Controller" />
    <context:include-filter type="annotation" expression="org.springframework.stereotype.Service" />
  </context:component-scan>

3、部署啟動項目,即可在加載完spring后就打印出“加載”

applicationontext和使用MVC之后的webApplicationontext會兩次調(diào)用上面的方法,如何區(qū)分這個兩種容器呢?

但是這個時候,會存在一個問題,在web項目中(springmvc),系統(tǒng)會存在兩個容器,一個是rootapplicationcontext,另一個就是我們自己的projectName-servletcontext(作為rootapplicationcontext的子容器)。

這種情況下,就會造成onApplicationEvent方法被執(zhí)行兩次。為了避免上面提到的問題,我們可以只在rootapplicationcontext初始化完成后調(diào)用邏輯代碼,其他的容器的初始化完成,則不做任何處理,修改后代碼

如下:

?
1
2
3
4
5
6
@Override
   public void onApplicationEvent(ContextRefreshedEvent event) {
    if(event.getApplicationContext().getParent() == null){//root application context 沒有parent,他就是老大.
       //需要執(zhí)行的邏輯代碼,當(dāng)spring容器初始化完成后就會執(zhí)行該方法。
    }
   }

初始化的順序是:

Constructor > @PostConstruct > InitializingBean > init-method

總結(jié)

以上就是本文關(guān)于Spring框架初始化解析的全部內(nèi)容,希望對大家有所幫助。如有問題可以隨時留言,小編會及時回復(fù)大家的。感謝朋友們對本站的支持!

原文鏈接:http://blog.csdn.net/simplemurrina/article/details/70991008

延伸 · 閱讀

精彩推薦
主站蜘蛛池模板: 久久蜜桃香蕉精品一区二区三区 | 黄色片视频在线观看 | 亚洲综合视频网 | 国产亚洲精品视频中文字幕 | 色婷婷a| 综合色视频 | 国产免费观看视频 | 国产露脸精品爆浆视频 | 久久99久久98精品免观看软件 | 欧美日韩激情 | 202z中文字幕第一页 | 久久久青 | 黄色电影免费提供 | 99久久精品日本一区二区免费 | 中文字幕精品一区久久久久 | 久久成人国产精品 | 欧美三级日本三级少妇99 | 538任你躁在线精品视频网站 | 成年人在线视频观看 | 成人免费在线观看视频 | 日本a大片| 国产69精品久久久久99尤 | 国产午夜精品久久久 | 毛片av网 | 免费网址黄 | 久久久久久久久久久亚洲 | 精品一区二区三区免费看 | 草草影院地址 | 欧美高清视频一区 | 欧美黄色一级片在线观看 | 成人性视频在线 | 亚洲最大中文字幕 | 亚洲精品一区中文字幕 | 久久99精品久久久久久236 | 亚洲精久 | 影视免费观看 | 久久精品99北条麻妃 | 九九热精 | 一级成人欧美一区在线观看 | 中文字幕偷拍 | 精品在线观看一区二区 |