Spring教程检视阅读

软件发布|下载排行|最新软件

当前位置:首页IT学院IT技术

Spring教程检视阅读

卡斯特梅的雨伞   2020-03-17 我要评论
Spring教程检视阅读 地址 可供参考的教程 《菜鸟学 SSH》 《Spring Boot 那些事》 《初识 Spring Security》 《Spring MVC 4.2.4.RELEASE 中文文档》 Spring 框架的参考手册 Spring IoC 容器 BeanFactory 和相关的接口,比如BeanFactoryAware、DisposableBean、InitializingBean,仍旧保留在 Spring 中,主要目的是向后兼容已经存在的和那些 Spring 整合在一起的第三方框架。 在 Spring 中,有大量对 BeanFactory 接口的实现。其中,最常被使用的是 XmlBeanFactory 类。这个容器从一个 XML 文件中读取配置元数据,由这些元数据来生成一个被配置化的系统或者应用。 在资源宝贵的移动设备或者基于 applet 的应用当中, BeanFactory 会被优先选择。否则,一般使用的是 ApplicationContext,除非你有更好的理由选择 BeanFactory。 ApplicationContext 包含 BeanFactory 所有的功能,一般情况下,相对于 BeanFactory,ApplicationContext 会更加优秀。当然,BeanFactory 仍可以在轻量级应用中使用,比如移动设备或者基于 applet 的应用程序。 最常被使用的 ApplicationContext 接口实现: - FileSystemXmlApplicationContext:该容器从 XML 文件中加载已被定义的 bean。在这里,你需要提供给构造器 XML 文件的完整路径。 - ClassPathXmlApplicationContext:该容器从 XML 文件中加载已被定义的 bean。在这里,你不需要提供 XML 文件的完整路径,只需正确配置 CLASSPATH 环境变量即可,因为,容器会从 CLASSPATH 中搜索 bean 配置文件。 - WebXmlApplicationContext:该容器会在一个 web 应用程序的范围内加载在 XML 文件中已被定义的 bean。 Spring Bean 下图表达了Bean 与 Spring 容器之间的关系: Spring 配置元数据 Spring IoC 容器完全由实际编写的配置元数据的格式解耦。有下面三个重要的方法把配置元数据提供给 Spring 容器: - 基于 XML 的配置文件 - 基于注解的配置 - 基于 Java 的配置 Bean 的作用域 当在 Spring 中定义一个 bean 时,你必须声明该 bean 的作用域的选项。例如,为了强制 Spring 在每次需要时都产生一个新的 bean 实例,你应该声明 bean 的作用域的属性为 prototype。同理,如果你想让 Spring 在每次需要时都返回同一个bean实例,你应该声明 bean 的作用域的属性为 singleton。 Spring 框架支持以下五个作用域,分别为singleton、prototype、request、session和global session,5种作用域说明如下所示, 注意,如果你使用 web-aware ApplicationContext 时,其中三个是可用的。 作用域 描述 singleton 在spring IoC容器仅存在一个Bean实例,Bean以单例方式存在,默认值 prototype 每次从容器中调用Bean时,都返回一个新的实例,即每次调用getBean()时,相当于执行newXxxBean() request 每次HTTP请求都会创建一个新的Bean,该作用域仅适用于WebApplicationContext环境 session 同一个HTTP Session共享一个Bean,不同Session使用不同的Bean,仅适用于WebApplicationContext环境 global-session 一般用于Portlet应用环境,该运用域仅适用于WebApplicationContext环境 singleton 作用域: 默认是singleton,在单例情况下,bean对象在某处的改变会影响到后面或者正在使用该bean的结果。因为一变全变。而prototype则每次获取的都是一个新的实例,所有对某个bean实例改变只对该bean有效,对其他值不变,其他bean创建时都是带默认的创建值状态。 prototype 作用域 当一个bean的作用域为Prototype,表示一个bean定义对应多个对象实例。Prototype作用域的bean会导致在每次对该bean请求(将其注入到另一个bean中,或者以程序的方式调用容器的getBean()方法)时都会创建一个新的bean实例。Prototype是原型类型,它在我们创建容器的时候并没有实例化,而是当我们获取bean的时候才会去创建一个对象,而且我们每次获取到的对象都不是同一个对象。根据经验,对有状态的bean应该使用prototype作用域,而对无状态的bean则应该使用singleton作用域。 Spring Bean 生命周期 Bean的生命周期可以表达为:Bean的定义——Bean的初始化——Bean的使用——Bean的销毁 为了定义安装和拆卸一个 bean,我们只要声明带有 init-method 和/或 destroy-method 参数的 。 建议你不要使用 InitializingBean 或者 DisposableBean 的回调方法,因为 XML 配置在命名方法上提供了极大的灵活性。 如果你有太多具有相同名称的初始化或者销毁方法的 Bean,那么你不需要在每一个 bean 上声明初始化方法和销毁方法。框架使用 元素中的 default-init-method 和 default-destroy-method 属性提供了灵活地配置这种情况 。 例子: 注意:当bean声明作用域为scope="prototype" 原型时,是不会执行destroy-method="destroy"方法,调用 context.registerShutdownHook();是不会执行的,因为对于容器来说原型的bean没有被销毁的概念,要用的时候就创建一个,只有当scope="singleton" 单例时才会执行这个destroy()钩子方法。 public class Message { //在bean对象中声明初始化和结束工作后的方法 public void init(){ System.out.println("----------------init-----------------"); } public void destroy(){ System.out.println("----------------destroy-----------------"); } } 在配置bean实例时加入init-method 和 destroy-method

Copyright 2022 版权所有 软件发布 访问手机版

声明:所有软件和文章来自软件开发商或者作者 如有异议 请与本站联系 联系我们