1. 对象创建:单例/多例  【bean节点的属性scope】

    • scope="singleton", 默认值,即默认是单例     【service/dao/工具类】
    • scope="prototype",                       多例  【Action】
    •  @Test
      public void testScope() throws Exception {
      ApplicationContext ac =
      new ClassPathXmlApplicationContext("cn/fuyi/a_helloworld/ApplicationContext.xml");
      User user1 = (User)ac.getBean("user");
      User user2 = (User)ac.getBean("user");
      System.out.println(user1);
      System.out.println(user2);
      System.out.println(user1 == user2);
      } /**Output
      当设置 scope="singleton"时
      cn.fuyi.a_helloworld.User@70941f0a
      cn.fuyi.a_helloworld.User@70941f0a
      true
      当设置 scope="prototype"时
      cn.fuyi.a_helloworld.User@70941f0a
      cn.fuyi.a_helloworld.User@c820344
      false
      */

      test Code

  2. 什么时候创建?
    • scope="singletom",     在启动IOC容器时,就已经创建了bean,且整个应用中只有一个
    • scope="prototype",      在用到的时候,才创建对象
 重写User的无参构造函数
public User() {
System.out.println("----user创建----");
} @Test
public void testScope1() throws Exception {
ApplicationContext ac =
new ClassPathXmlApplicationContext("cn/fuyi/a_helloworld/ApplicationContext.xml");
System.out.println("----容器创建----"); User user = (User)ac.getBean("user");
System.out.println(user);
}
/**Output
当scope="singleton"时
----user创建----
----容器创建----
cn.fuyi.a_helloworld.User@36446fd2
当scope="prototype"时
----容器创建----
----user创建----
cn.fuyi.a_helloworld.User@7d311feb
*/

test Code

  3. 是否延迟创建,只在scope="singleton"时有效 【bean节点的属性lazy-init】

    • lazy-init="default" / lazy-init="false"          默认值,在启动IOC容器时,就已经创建了bean,且整个应用中只有一个
    • lazy-init="true"                                        在第一次使用单例对象时,创建对象,只创建一次

  4.创建对象之后,初始化/销毁   【bean节点的属性init-mothod/destroy-mothod】

    • init-mothod="init_user"                        对应对象的init_user()方法,在对象创建完成之后执行
    • destroy-mothod="destroy_user"            在调用容器对象的destroy()方法时执行,此时容器用实现类,即
    • 亲测:对象创建为单例时两者可正常执行,为多例时每次创建对象后都会执行init-mothod,只后不会执行destroy-mothod.
    •  在User对象中添加
      public void init_method() {
      System.out.println("user对象初始化");
      } public void destory_method() {
      System.out.println("user对象销毁");
      } @Test
      public void testLazyInit() throws Exception {
      //创建容器
      ClassPathXmlApplicationContext ac =
      new ClassPathXmlApplicationContext("cn/fuyi/a_helloworld/ApplicationContext.xml");
      System.out.println("----容器创建----"); //从容器中获取bean
      User user = (User)ac.getBean("user");
      System.out.println(user); //销毁容器
      ac.destroy();
      }
      /**Output
      在scope="singleton"时
      ----user创建----
      user对象初始化
      ----容器创建----
      cn.fuyi.a_helloworld.User@46cb560b
      user对象销毁
      在scope="prototype"时
      ----容器创建----
      ----user创建----
      user对象初始化
      cn.fuyi.a_helloworld.User@60209661 */

      test Code

  5.创建对象

    • 使用构造器
    •  <!-- 创建对象 -->
      <!-- 1.默认使用无参构造器 -->
      <bean id="user1" class="cn.fuyi.b_createobject.User"></bean> <!-- 2.使用有参构造器 -->
      <bean id="user1" class="cn.fuyi.b_createobject.User">
      <constructor-arg value="22" index="1" type="java.lang.Integer"></constructor-arg>
      <constructor-arg value="Jack" index="0" type="java.lang.String"></constructor-arg>
      </bean> <bean id="str" class="java.lang.String">
      <constructor-arg value="Jacks"></constructor-arg>
      </bean>
      <bean id="user" class="cn.fuyi.b_createobject.User">
      <constructor-arg value="22" index="1" type="java.lang.Integer"></constructor-arg>
      <constructor-arg ref="str" index="0" type="java.lang.String"></constructor-arg>
      </bean>
    • 使用工厂类

       <!-- 工厂类创建对象 -->
      <!-- 工厂类:实例方法 -->
      <!-- 先创建工厂类 -->
      <bean id="factory" class="cn.fuyi.b_createobject.ObjectFactory"></bean>
      <bean id="user1" factory-bean="factory" factory-method="getInstance"></bean> <!-- 工厂类:静态方法
      class 指定工厂类型
      factory-method 指定静态工厂方法
      -->
      <bean id="user" class="cn.fuyi.b_createobject.ObjectFactory" factory-method="getStaticInstance"></bean>

6.对象属性赋值,即注入依赖关系

    • 使用构造器
    • 使用set方法注入(建议)
 <!-- 对象属性赋值 -->
<!-- 1.通过构造函数 -->
<bean id="user" class="cn.fuyi.c_setProperty.User">
<constructor-arg index="0" value="Jack" type="java.lang.String"></constructor-arg>
<constructor-arg index="1" value="100" type="java.lang.Integer"></constructor-arg>
</bean> <!-- 2.通过set方法给属性注入值 -->
<bean id="user" class="cn.fuyi.c_setProperty.User">
<property name="lastName" value="Fuyi"></property>
<property name="age" value="100"></property>
</bean>
    • 使用内部bean

       <bean id="userAction" class="cn.fuyi.c_setProperty.UserAction" scope="prototype">
      <property name="userService">
      <bean class="cn.fuyi.c_setProperty.UserService" scope="singleton">
      <property name="userDao">
      <bean class="cn.fuyi.c_setProperty.UserDao" scope="singleton"></bean>
      </property>
      </bean>
      </property>
      </bean>
    • 使用p  命名空间给对象属性注入值,【在spring3.0以上版本才可使用】
           <bean id="userDao" class="cn.fuyi.c_setProperty.UserDao"></bean>
      <bean id="userService" class="cn.fuyi.c_setProperty.UserService" p:userDao-ref="userDao"></bean>
      <bean id="userAction" class="cn.fuyi.c_setProperty.UserAction" p:userService-ref="userService"></bean> <bean id="user" class="cn.fuyi.c_setProperty.User" p:lastName="fuyi" p:age="110"></bean>
    • 自动装配

       <!-- 也可以在beans节点的属性default-autowire中统一设置
      byName 根据名称自动装配
      byType 根据类型自动装配,必须确保IOC容器中只有一个该类型的对象
      -->
      <bean id="userDao" class="cn.fuyi.c_setProperty.UserDao"></bean>
      <bean id="userService" class="cn.fuyi.c_setProperty.UserService" autowire="byName"></bean>
      <bean id="userAction" class="cn.fuyi.c_setProperty.UserAction" autowire="byName"></bean>
    • 使用注解(建议)
      • 使用注解步骤
      1. 开启注解扫描

        <context:component-scan base-package="cn.fuyi.c_setProperty"></context:component-scan>
      2. 使用注解    
 @Component("userService")    //相当于 [<bean id="userService"  class="" />],在类上加
@Resource(name="userDao") //相当于 [<property name="userDao" ref="userDao" />] @Component 默认value="userService", 类名,首字母小写
@Resource 默认name="userDao" 类名,首字母小写 @Repository 持久层
@Service 业务层
@Controller 控制层

       @Resource    根据类型查找

       @Resource(name="userDao")    根据名称查找

spring来了-03-bean创建细节的更多相关文章

  1. Spring第二篇【Core模块之快速入门、bean创建细节、创建对象】

    前言 上篇Spring博文主要引出了为啥我们需要使用Spring框架,以及大致了解了Spring是分为六大模块的-.本博文主要讲解Spring的core模块! 搭建配置环境 引入jar包 本博文主要是 ...

  2. Spring中常见的bean创建异常

    Spring中常见的bean创建异常 1. 概述     本次我们将讨论在spring中BeanFactory创建bean实例时经常遇到的异常 org.springframework.beans.fa ...

  3. Spring AOP 源码分析 - 创建代理对象

    1.简介 在上一篇文章中,我分析了 Spring 是如何为目标 bean 筛选合适的通知器的.现在通知器选好了,接下来就要通过代理的方式将通知器(Advisor)所持有的通知(Advice)织入到 b ...

  4. spring中自动装配bean

    首先用@Component注解类: package soundsystem: import org.springframework.stereotype.Component; @Component p ...

  5. 阶段3 2.Spring_03.Spring的 IOC 和 DI_6 spring中bean的细节之三种创建Bean对象的方式

    目前这里能调用是因为,在service的实现类里面,new了一个dao的对象 正常情况下 这里不应该是new一个对象,应该等于null或为空 设置为空侯再运行就会报错 出错的原因是这里为null 需要 ...

  6. Java进阶知识17 Spring Bean对象的创建细节和创建方式

    本文知识点(目录): 1.创建细节         1) 对象创建: 单例/多例         2) 什么时候创建?         3)是否延迟创建(懒加载)         4) 创建对象之后, ...

  7. Spring读书笔记——bean创建(下)

    有关Spring加载bean系列,今天这是最后一篇了,主要接上篇对于从Spring容器中获取Bean的一些细节实现的补充. <Spring读书笔记--bean加载>--Spring如何加载 ...

  8. IDEA02 利用Maven创建Web项目、为Web应用添加Spring框架支持、bean的创建于获取、利用注解配置Bean、自动装配Bean、MVC配置

    1 环境版本说明 Jdk : 1.8 Maven : 3.5 IDEA : 专业版 2017.2 2 环境准备 2.1 Maven安装及其配置 2.2 Tomcat安装及其配置 3 详细步骤 3.1 ...

  9. Spring 源码 (1)Spring IOC Bean 创建的整体流程

    Spring IOC 中涉及的重要接口 BeanDefinition Bean的描述信息,实现类包括 RootBeanDefinition 和 GenericBeanDefinition,Bean的描 ...

  10. Spring读书笔记——bean创建(上)

    通过<Spring读书笔记--bean加载>和<Spring读书笔记--bean解析>,我们明白了两件事. Spring如何加载消化一个xml配置文件 Spring如何将xml ...

随机推荐

  1. 解决Win7下UAC开启时无法响应WM_DROPFILES消息

    //以管理员身份运行,程序窗口就可以接收到拖放文件消息[WM_DROPFILES]了. ChangeWndMessageFilterOk(WM_DROPFILES, MSGFLT_ADD); Chan ...

  2. 第二课 android项目结构

  3. ASP.NET简单登录注册实例

    <%@ Page Language="C#" AutoEventWireup="true" CodeBehind="WebForm1.aspx. ...

  4. 【转载】创建和使用动态链接库 (C++)

    原文:http://blog.csdn.net/handforcpp/article/details/3478254 也可参考MSDN: 演练:创建和使用动态链接库 (C++) 我们将创建的第一种类型 ...

  5. firefox 安装flash插件

    第一步下载并解压flash解压出一个文件:libflashplayer.so 和文件夹usr 第二步查找plugins其他程序或许也有这个文件夹所以先查找firefox在查找mozilla看在哪个文件 ...

  6. 第五章 consul key/value

    1.key/value作用 动态修改配置文件 支持服务协同 建立leader选举 提供服务发现 集成健康检查 2.使用 2.1.查看全部key/value 说明: 使用?recurse参数来指定查看多 ...

  7. More Effective C++ (1)

    简单分析总结了more effective c++ 的前十个条款: 剩下的条款to be continue~ 1.仔细区分指针和引用引用必须不能指向空,指针可以指向空,指针初始化是记得赋空值,重载某些 ...

  8. 使jQuqer更高效的方法

    讨论 jQuery 和 javascript 性能的文章并不罕见.然而,本文我计划总结一些速度方面的技巧和我本人的一些建议,来提升你的 jQuery 和 javascript 代码.好的代码会带来速度 ...

  9. Nginx模块学习之————accesskey权限模块使用(简单的m3u8防盗链)

    配置文件:http://www.cnblogs.com/tinywan/p/5983694.html 通过加密后的文件: 正确地址:curl -i http://访问的IP地址(这里是直播节点IP地址 ...

  10. web设计经验<二>设计华丽的用户体验的6个热门技巧

    你是否曾经下载了一个应用,却发现它“很难使用”?对于大多数智能手机用户来说,答案是肯定的. 有趣的是,每四个手机应用中就有一个应用在下载后被“打入冷宫”. 如果一个应用能够吸引一个人下载并且打开它,但 ...