首页 > 其他分享 >Spring创建Bean的三种方式及Bean的生命周期

Spring创建Bean的三种方式及Bean的生命周期

时间:2023-12-20 20:59:36浏览次数:26  
标签:生命周期 saveAccount Spring System 创建对象 Bean println public out

目录

Spring创建Bean的三种方式及Bean的生命周期

Spring创建Bean的三种方式

第一种方式:使用默认构造函数创建

在spring的配置文件中使用bean标签,配以id和class属性之后,且没有其他属性和标签时。
采用的就是默认构造函数创建bean对象,此时如果类中没有默认构造函数,则对象无法创建。

Spring配置文件

<bean id="accountServiceOne" class="com.zjw.service.impl.AccountServiceOneImpl" />

Java类

package com.zjw.service.impl;

import com.zjw.service.IAccountServiceOne;

/**
 * 账户的业务层实现类
 * 对象创建的三种方式一:通过构造方法创建对象
 */
public class AccountServiceOneImpl implements IAccountServiceOne {
    
    public AccountServiceOneImpl() {
        System.out.println("AccountServiceOneImpl……我创建了。。");
    }

    @Override
    public void saveAccount() {
        System.out.println("AccountServiceOneImpl中的saveAccount方法执行了");
    }
}

测试


/**
 * 模拟一个表现层,用于调用业务层
 */
public class Client {

    public static void main(String[] args)  {

        ClassPathXmlApplicationContext ac = new ClassPathXmlApplicationContext("bean.xml");

        //对象创建的三种方式一:通过构造方法创建对象
        IAccountServiceOne accountServiceOne = (IAccountServiceOne) ac.getBean("accountServiceOne");
        System.out.println(accountServiceOne);
        accountServiceOne.saveAccount();

        System.out.println("main 方法结束了。。。。");

    }
}

结果

AccountServiceOneImpl……我创建了。。。
com.zjw.service.impl.AccountServiceOneImpl@258e2e41
AccountServiceOneImpl中的saveAccount方法执行了
main 方法结束了。。。。

第二种方式:使用普通工厂中的方法创建对象

使用普通工厂中的方法创建对象(使用某个类中的方法创建对象,并存入spring容器)

Spring配置

    <!--第二种方式:使用普通工厂中的方法创建对象(使用某个类中的方法创建对象,并存入spring容器)-->
    <bean id="instanceFactory" class="com.zjw.factory.InstanceFactory"/>
    <bean id="accountServiceTwo" factory-bean="instanceFactory" factory-method="getAccountService" />

工厂类

/**
 * @author zjw
 */
public class InstanceFactory {

    public IAccountServiceTwo getAccountService(){
        return new AccountServiceTwoImpl();
    }
}

Java类

/**
 * 账户的业务层实现类
 * 第二种方式:使用普通工厂中的方法创建对象(使用某个类中的方法创建对象,并存入spring容器)
 */
public class AccountServiceTwoImpl implements IAccountServiceTwo {
    
    public AccountServiceTwoImpl() {
        System.out.println("AccountServiceTwoImpl……我创建了。。");
    }

    @Override
    public void saveAccount() {
        System.out.println("AccountServiceTwoImpl中的saveAccount方法执行了");
    }
}

测试

/**
 * 模拟一个表现层,用于调用业务层
 */
public class Client {

    public static void main(String[] args)  {

        ClassPathXmlApplicationContext ac = new ClassPathXmlApplicationContext("bean.xml");

        //第二种方式:使用普通工厂中的方法创建对象
        IAccountServiceTwo accountServiceTwo = ac.getBean("accountServiceTwo", IAccountServiceTwo.class);
        System.out.println(accountServiceTwo);
        accountServiceTwo.saveAccount();

        System.out.println("main 方法结束了。。。。");
    }
}

结果

AccountServiceTwoImpl……我创建了。。
com.zjw.service.impl.AccountServiceTwoImpl@258e2e41
AccountServiceTwoImpl中的saveAccount方法执行了
main 方法结束了。。。。

第三种方式:使用工厂中的静态方法创建对象

Spring配置

    <!--第三种方式:使用工厂中的静态方法创建对象(使用某个类中的静态方法创建对象,并存入spring)-->
    <bean id="accountServiceThree" class="com.zjw.factory.StaticFactory" factory-method="getAccountService" />

工厂类


public class StaticFactory {
    public static IAccountServiceThree getAccountService(){
        return new AccountServiceThreeImpl();
    }
}

Java类

/**
 * 账户的业务层实现类
 * 第三种方式:使用工厂中的静态方法创建对象(使用某个类中的静态方法创建对象,并存入spring)
 */
public class AccountServiceThreeImpl implements IAccountServiceThree {

    public AccountServiceThreeImpl() {
        System.out.println("AccountServiceThreeImpl……我创建了。。");
    }

    @Override
    public void saveAccount() {
        System.out.println("AccountServiceThreeImpl中的saveAccount方法执行了");
    }
}

测试

/**
 * 模拟一个表现层,用于调用业务层
 */
public class Client {

    public static void main(String[] args)  {

        ClassPathXmlApplicationContext ac = new ClassPathXmlApplicationContext("bean.xml");
        
        //第二种方式:使用工厂中的静态方法创建对象
        IAccountServiceThree accountServiceThree= ac.getBean("accountServiceThree", IAccountServiceThree.class);
        System.out.println(accountServiceThree);
        accountServiceThree.saveAccount();

        System.out.println("main 方法结束了。。。。");

    }
}

结果

AccountServiceThreeImpl……我创建了。。
com.zjw.service.impl.AccountServiceThreeImpl@258e2e41
AccountServiceThreeImpl中的saveAccount方法执行了
main 方法结束了。。。。

Bean的生命周期

  • 单例对象

出生:当容器创建时对象出生

活着:只要容器还在,对象一直活着

死亡:容器销毁,对象给你消亡

总结:单例对象的生命周期和容器相同

  • 多例对象

出生:当我们使用对象时spring框架为我们创建

活着:对象只要是在使用过程中就一直活着

死亡:当对象长时间不用,且没有别的对象引用时,由Java的垃圾回收器回收

Spring配置

    <!--
        init-method:对象创建后执行的方法
        destroy-method:对象销毁时执行的方法
            单例对象,容器关闭后执行
            多例模式,java虚拟机决定
        scope:单例还是多例对象
            singleton:默认,单例
            prototype:多例
    -->
    <bean id="accountService" class="com.zjw.service.impl.AccountServiceImpl"
          init-method="init" destroy-method="destroy" />

Java类

/**
 * 账户的业务层实现类
 */
public class AccountServiceImpl implements IAccountService {
    
    public AccountServiceImpl() {
        System.out.println("AccountServiceImpl……我创建了。。");
    }

    @Override
    public void saveAccount() {
        System.out.println("AccountServiceImpl……saveAccount方法执行了");
    }

    public void init(){
        System.out.println("AccountServiceImpl……init方法执行了。。");
    }

    public void destroy(){
        System.out.println("AccountServiceImpl……destroy方法执行了。。");
    }
}

测试

/**
 * 模拟一个表现层,用于调用业务层
 */
public class Client {

    public static void main(String[] args)  {

        ClassPathXmlApplicationContext ac = new ClassPathXmlApplicationContext("bean.xml");

        //Bean的生命周期
        IAccountService accountService = (IAccountService) ac.getBean("accountService");
        System.out.println(accountService);
        accountService.saveAccount();
        System.out.println(ac.isSingleton("accountService"));

        ac.close();
        System.out.println(accountService);
        System.out.println("main 方法结束了。。。。");
    }
}

结果

AccountServiceImpl……我创建了。。
AccountServiceImpl……init方法执行了。。
com.zjw.service.impl.AccountServiceImpl@add0edd
AccountServiceImpl……saveAccount方法执行了
true
AccountServiceImpl……destroy方法执行了。。
com.zjw.service.impl.AccountServiceImpl@add0edd
main 方法结束了。。。。

标签:生命周期,saveAccount,Spring,System,创建对象,Bean,println,public,out
From: https://www.cnblogs.com/zjw-blog/p/17917532.html

相关文章

  • springboot051医院管理系统-计算机毕业设计源码+LW文档
    一、立题依据(研究的目的与意义及国内外现状):现如今,互联网的广泛普及与应用,标志着信息化的时代已经到来,管理信息化行业在生活中占据着越来越重要的地位,信息化的服务与管理,大大简化了传统的管理模式,很大程度上,改善了使得人们的生活水平和工作方式。简单的来说医院管理信息化的形式非......
  • springboot053宠物咖啡馆平台-计算机毕业设计源码+LW文档
    摘要随着信息技术在管理上越来越深入而广泛的应用,管理信息系统的实施在技术上已逐步成熟。本文介绍了基于SpringBoot的宠物咖啡馆平台的设计与实现的开发全过程。通过分析基于SpringBoot的宠物咖啡馆平台的设计与实现管理的不足,创建了一个计算机管理基于SpringBoot的宠物咖啡馆......
  • springboot054飘香水果购物网站 -计算机毕业设计源码+LW文档
    摘要随着信息互联网购物的飞速发展,一般企业都去创建属于自己的电商平台以及购物管理系统。本文介绍了飘香水果购物网站的开发全过程。通过分析企业对于飘香水果购物网站的需求,创建了一个计算机管理飘香水果购物网站的方案。文章介绍了飘香水果购物网站的系统分析部分,包括可行性分......
  • springboot055服装生产管理-计算机毕业设计源码+LW文档
    一、现状、意义和目的1.背景与现状近年来,随着经济全球化与科技管理信息化的协同发展,而又因服装业所面对的是终端消费者市场,是由消费者主导的供应链,服装需求更加多样化,致使服装市场的竞争日趋激烈。随之产品生命周期变短,消费者数量的不断增多及需求快速多变等特性导致服装需求激增,协......
  • springboot052旅游管理系统 -计算机毕业设计源码+LW文档
    摘 要随着旅游业的迅速发展,传统的旅游信息查询方式,已经无法满足用户需求,因此,结合计算机技术的优势和普及,针对常州旅游,特开发了本基于Bootstrap的常州地方旅游管理系统。 本论文首先对常州地方旅游管理系统进行需求分析,从系统开发环境、系统目标、设计流程、功能设计等几个方面......
  • beanshell导入java文件
    beanshell导入java文件beanshell可以读取class格式的文件步骤:    a、添加BeanShell预处理程序    b、请求调用   beanshell可以读取java格式的文件步骤:    a、添加BeanShell预处理程序    b、请求调用  ......
  • SpringBoot自动配置解析
    依赖管理在pom文件中最核心依赖就是:<parent>  <groupId>org.springframework.boot</groupId>  <artifactId>spring-boot-starter-parent</artifactId>  <version>2.4.4</version>  <relativePath/></parent>父项目依赖,规定所有依赖的版本......
  • SpringBoot代码混淆与反混淆加密工具详解
    ​ SpringBoot代码混淆与反混淆加密工具详解简单就是把代码跑一哈,然后我们的代码.java文件就被编译成了.class文件   ​反编译就是针对编译生成的jar/war包里面的.class文件逆向还原回来,可以看到你的代码写的啥。比较常用的反编译工具JD-GUI,直接把编译......
  • spring-cloud 微服务架构所用到的技术 简介
    https://www.bilibili.com/video/BV18E411x7eThttps://blog.csdn.net/u011863024/article/details/114298270https://blog.csdn.net/u011863024/article/details/114298282https://blog.csdn.net/u011863024/article/details/1142982881、注册中心注册中心这一概念在面向服......
  • 类的生命周期及执行顺序
    类的生命周期一个类完整的生命周期,会经历五个阶段,分别为:加载、连接、初始化、使用和卸载。其中的连接又分为验证、准备和解析三个步骤。如下图所示:简单一句话概括,类的加载机制就是:找到需要加载的类并把类的信息加载到jvm的方法区中),然后在堆区中实例化一个java.lang.Class对象,......