Spring 提供组件扫描(component scanning)功能。它能从指定的classpath里自动扫描、侦测和实例化具备特定注解的组件。前端
基本的注解是@Component,@Name它标识一个受Spring管理的组件。其余特定的注解有@Repository、@Service和@Controller,它们分别标识了持久层注解、业务层注解和控制层注解的组件。java
1.1)在配置文件添加自动组件扫描配置web
<!-- 组件扫描 自动 扫描com.spring包以及子包下全部的组件类--> <context:component-scan base-package="com.spring"></context:component-scan>
1.2)新建一个TestComponentScan类 分别添加一个无参构造器,一个初始化方法和一个销毁回调方法(@PostConstruct和PreDestroy注解分别用于指定初始化和销毁回调方法。初始化和销毁还能够经过配置文件init-method,destroy-method属性来执行初始化和销毁《注意:只有单例模式才会spring才会自动调用销毁方法》)spring
package com.spring.dao;
import javax.annotation.PostConstruct; import javax.annotation.PreDestroy; import org.springframework.stereotype.Component; @Component public class TestComponentScan { public TestComponentScan() { System.out.println("-------------实例化对象-------------"); } @PostConstruct public void init(){ System.out.println("-------------初始化对象-------------"); } @PreDestroy public void destroy(){ System.out.println("-------------销毁对象-------------"); } }
1.3)在测试类添加testComponentScan方法设计模式
@Test
public void testComponentScan(){ String con = "applicationContext.xml"; AbstractApplicationContext ac = new ClassPathXmlApplicationContext(con); TestComponentScan tcs = ac.getBean("testComponentScan",TestComponentScan.class); System.out.println(tcs); ac.close(); }
1.4)控制台输出咱们写的打印信息就说明自动组件扫描成功了缓存
Spring容器最初提供了两种bean的Scope类型:1.@Scope("singleton"),2@Scope("prototype"),默认类型为Singleton。可是2.0发布后新增了三种scope类型request、session和global session,这三种只能在web 应用中才可使用。(后面三种暂时没用过不详细看了)服务器
request:每次http请求将会有各自的bean实例,相似于prototype。 session
session:在一个http session中,一个bean定义对应一个bean实例。app
global session:在一个全局的http session中,一个bean定义对应一个bean实例。典型状况下,仅在使用portlet context的时候有效。框架
2.1)singleton和prototype的区别
Singleton:当一个bean的做用域设置为singleton时,那么Spring IOC容器只会存在一个共享bean实例,而且全部对bean的请求,只要id与该bean定义相匹配,则只会返回bean的同一实例。换言之,当把一个bean定义设置为singleton做用域时,Spring IOC容器只会建立该bean定义的惟一实例。这个单一实例会被存储到单例缓存(singleton cache)中,而且全部针对该bean的后续请求和引用都将返回被缓存的对象实例。
***这里要注意的是singleton做用域和GOF设计模式中的单例是彻底不一样的,单例设计模式表示一个ClassLoader中只有一个class存在,而这里的singleton则表示一个容器对应一个bean,也就是说当一个bean被标识为singleton时候,spring的IOC容器中只会存在一个该bean。***
Prototype:prototype做用域部署的bean,每一次请求(将其注入到另外一个bean中,或者以程序的方式调用容器的getBean()方法)都会产生一个新的bean实例,至关与一个new的操做,对于prototype做用域的bean,有一点很是重要,那就是Spring不能对一个prototype bean的整个生命周期负责,容器在初始化、配置、装饰或者是装配完一个prototype实例后,将它交给客户端,随后就对该prototype实例漠不关心了。
无论何种做用域,容器都会调用全部对象的初始化生命周期回调方法,而对prototype而言,任何配置好的析构生命周期回调方法都将不会被调用。清除prototype做用域的对象并释听任何prototype bean所持有的昂贵资源,都是客户端代码的职责。(让Spring容器释放被singleton做用域bean占用资源的一种可行方式是,经过使用bean的后置处理器,该处理器持有要被清除的bean的引用。)
2.2)写一个测试方法测试一下singleton只建立一个实例,而prototype每次调用都会建立一个新的实例
2.2.1在TestComponnetScan类中添加@Scope注解
@Scope("singleton")
2.2.2)在测试方法中,再调用一次getBean()方法,而且判断这两个对象知否指向同一个
TestComponentScan tcs2 = ac.getBean("testComponentScan",TestComponentScan.class);
System.out.println(tcs==tcs2);
2.2.3)Junit运行,能够从控制台看出只实例化了一次,而且两个对象指向同一实例
2.2.4)修改Scope注解为prototype模式
2.2.5)Junit运行,能够从控制台看出调用两次getBean,实例化,初始化了两次,而且两个对象指向不是同一实例
MVC模式简介:M:Model模型。Model的职责是负责业务逻辑。包含两层:业务数据和业务处理逻辑。好比实体类,Dao,Service都属于Model层
V:view视图。View的职责是负责显示页面和用户交互(收集用户信息)。属于视图的组件是不包含业务逻辑和控制逻辑的JSP。
C:Controller控制器。控制器是Model层和View层的桥梁用于控制流程。
Spring web MVC是Spring框架一个很是重要的功能模块。实现了MVC结构,便于简单,快速的开发MVC结构的Web程序。Spring web MVC 提供了API的封装Web开发中经常使用的功能。简化了Web开发过程。
1.1).Spring Web MVC的核心组件
1>DispatcherServlet(控制器请求入口)
2>HandllerMapping(控制器请求派发)
3>Controller(控制器,请求处理流程)
4>ModelAndVie(模型,封装 业务处理结果和视图)
5>ViewResolver(视图,示图显示处理器)
1.2)Spring Web MVC的处理流程